如需使用屏幕共享功能,请务必 获取用户录制屏幕授权,否则将无法使用该功能。
屏幕共享,是指在视频通话或互动直播过程中将屏幕内容以视频的方式分享给其他的观众,以增强互动体验,提高沟通效率。
屏幕共享在如下场景中应用广泛:
请参考 下载示例源码 获取源码。
相关源码请查看 “/ZegoExpressExample/Others/src/main/java/im/zego/others/screensharing” 目录下的文件。
others
└── screensharing
└── ScreenSharingActivity.java
...
在实现屏幕共享功能之前,请确保:
下图展示了 Android 平台实现屏幕共享的数据流转:
请务必声明以下权限,否则将无法使用屏幕共享功能。
在工程的 AndroidManifest.xml 文件中,增加屏幕录制的权限配置。设置完成后,在录制屏幕前,会弹窗提示用户是否允许应用录制屏幕,需要用户手动授权。
屏幕录制功能依赖于前台服务保活,进入您项目的 “app/src/main” 目录,打开 “AndroidManifest.xml” 文件,添加权限声明。
如果目标 Android SDK 版本低于 34.0.0 版本,需设置 FOREGROUND_SERVICE
权限声明。
<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
如果目标 Android SDK 版本是 34.0.0 及以后版本,需要设置 FOREGROUND_SERVICE
及 FOREGROUND_SERVICE_MEDIA_PROJECTION
权限声明。
<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
<uses-permission android:name="android.permission.FOREGROUND_SERVICE_MEDIA_PROJECTION"/>
声明屏幕录制的前台服务和辅助 Activity。
如果您使用的是 3.6.0 或以上版本的 SDK,且通过 Maven 自动集成(或手动集成 “.aar” 包)时,可以跳过此步骤。
如果您使用的是 3.6.0 以下版本的 SDK,必须手动声明屏幕录制的前台服务和辅助 Activity,否则无法启动屏幕录制。
<application>
<activity
android:name="im.zego.internal.screencapture.ZegoScreenCaptureManager$ZegoScreenCaptureAssistantActivity"
android:exported="false"
android:configChanges="screenSize|orientation"
android:screenOrientation="fullUser"
android:theme="@android:style/Theme.Translucent" />
<service
android:name="im.zego.internal.screencapture.ZegoScreenCaptureService"
android:enabled="true"
android:exported="false"
android:foregroundServiceType="mediaProjection">
<intent-filter>
<action android:name="android.intent.action.screenshare" />
</intent-filter>
</service>
</application>
SDK 推流的“视频源”默认为摄像头,如果需要推屏幕共享源,需要通过 setVideoSource 切换为屏幕共享。
engine.setVideoSource(ZegoVideoSourceType.SCREEN_CAPTURE, ZegoPublishChannel.MAIN);
SDK 推流的“音频源”默认为麦克风,如果需要推屏幕共享源,需要通过 setAudioSource 切换为屏幕共享。
engine.setAudioSource(ZegoAudioSourceType.SCREEN_CAPTURE, ZegoPublishChannel.MAIN);
调用 startScreenCapture 接口共享整个系统的画面、采集第三方应用的音频。
engine.startScreenCapture();
开发者还可以使用 ZegoScreenCaptureConfig 参数设置是否采集视频、是否采集音频、设置音频采集时的采样率和采样通道等。
ZegoScreenCaptureConfig config = new ZegoScreenCaptureConfig();
config.captureVideo = true;
config.captureAudio = true;
config.audioParam.sampleRate = ZegoAudioSampleRate.ZEGO_AUDIO_SAMPLE_RATE_16K;
config.audioParam.channel = ZegoAudioChannel.STEREO;
engine.startScreenCapture(config);
调用 updateScreenCaptureConfig 接口,可以更新屏幕共享的配置。
ZegoScreenCaptureConfig config = new ZegoScreenCaptureConfig();
config.captureVideo = true;
config.captureAudio = false;
config.audioParam.sampleRate = ZegoAudioSampleRate.ZEGO_AUDIO_SAMPLE_RATE_32K;
config.audioParam.channel = ZegoAudioChannel.STEREO;
engine.updateScreenCaptureConfig(config);
开发者需要监听 IZegoEventHandler 类中的以下回调:
public void setEngineEventHandler(){
engine.setEventHandler(new IZegoEventHandler() {
@Override
public void onScreenCaptureExceptionOccurred(ZegoScreenCaptureExceptionType exceptionType) {
super.onScreenCaptureExceptionOccurred(exceptionType);
AppLogger.getInstance().receiveCallback("screen capture exception occurred: %s", exceptionType);
}
@Override
public void onScreenCaptureStart() {
super.onScreenCaptureStart();
AppLogger.getInstance().receiveCallback("screen capture start");
}
});
}
调用 loginRoom 接口,传入房间 ID 参数 “roomID” 和用户参数 “user”,登录房间。
调用 startPublishingStream 接口,传入流 ID 参数 “streamID”,向远端用户发送本端的音视频流。
// 创建用户
ZegoUser user = new ZegoUser("user1");
// 开始登录房间
engine.loginRoom("room1", user);
// 开始推流
engine.startPublishingStream("stream1");
至此,我们已完成采集屏幕数据并通过 ZEGO Express SDK 分享到远端的操作。
完成以上步骤之后,其他用户可以使用 startPlayingStream 接口拉取屏幕共享流。
// 拉流播放,需传入发起屏幕共享的用户推流时所用的 streamID
engine.startPlayingStream(streamID, new ZegoCanvas(playView));
用户可以调用 stopScreenCapture 接口停止共享。
engine.stopScreenCapture();
联系我们
文档反馈