logo
实时音视频
当前页

屏幕共享

2025-01-20

注意

如需使用屏幕共享功能,请务必 获取用户录制屏幕授权,否则将无法使用该功能。

功能简介

屏幕共享,是指在视频通话或互动直播过程中将屏幕内容以视频的方式分享给其他的观众,以增强互动体验,提高沟通效率。

屏幕共享在如下场景中应用广泛:

  • 视频会议场景中,屏幕共享可以将讲话者本地的文件、数据、网页、PPT 等画面分享给其他与会人;
  • 在线课堂场景中,屏幕共享可以将老师的课件、笔记、讲课内容等画面展示给学生观看。

示例源码下载

请参考 下载示例源码 获取源码。

相关源码请查看 “/ZegoExpressExample/Others/src/main/java/im/zego/others/screensharing” 目录下的文件。

others
└── screensharing
    └── ScreenSharingActivity.java
...

前提条件

在实现屏幕共享功能之前,请确保:

实现流程

注意
  • 屏幕采集时,仅 iOS、Android 平台支持同时采集视频和音频;其他平台仅支持采集视频,如需采集音频,请开发者自行实现相关逻辑。
  • 如果您已经通过 ZEGO 旧版 屏幕共享 产品实现屏幕共享功能,或者需要自己实现屏幕共享功能,请参考 如何通过自定义采集实现屏幕共享?

下图展示了 Android 平台实现屏幕共享的数据流转:

1(必选)获取用户录制屏幕授权

注意

请务必声明以下权限,否则将无法使用屏幕共享功能。

在工程的 AndroidManifest.xml 文件中,增加屏幕录制的权限配置。设置完成后,在录制屏幕前,会弹窗提示用户是否允许应用录制屏幕,需要用户手动授权。

  1. 屏幕录制功能依赖于前台服务保活,进入您项目的 “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_SERVICEFOREGROUND_SERVICE_MEDIA_PROJECTION 权限声明。

      <uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
      <uses-permission android:name="android.permission.FOREGROUND_SERVICE_MEDIA_PROJECTION"/>
  2. 声明屏幕录制的前台服务和辅助 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>

2 设置采集源为屏幕共享源

  • SDK 推流的“视频源”默认为摄像头,如果需要推屏幕共享源,需要通过 setVideoSource 切换为屏幕共享。

    engine.setVideoSource(ZegoVideoSourceType.SCREEN_CAPTURE, ZegoPublishChannel.MAIN);
  • SDK 推流的“音频源”默认为麦克风,如果需要推屏幕共享源,需要通过 setAudioSource 切换为屏幕共享。

    engine.setAudioSource(ZegoAudioSourceType.SCREEN_CAPTURE, ZegoPublishChannel.MAIN);

3 开启屏幕共享

调用 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;
// 可选参数,设置视频的采集区域,必须在原始的视频数据之内,单位为像素(px)
config.cropRect = new Rect(left, top, right, bottom);

engine.startScreenCapture(config);

4 更新屏幕共享配置

调用 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;
// 可选参数,设置视频的采集区域,必须在原始的视频数据之内,单位为像素(px)
config.cropRect = new Rect(left, top, right, bottom);

engine.updateScreenCaptureConfig(config);

5 监听屏幕共享回调通知

开发者需要监听 IZegoEventHandler 类中的以下回调:

  • onScreenCaptureStart 回调,接收开始屏幕采集成功的通知,方便做后续业务处理,如 UI 提示或应用跳转等。
  • onScreenCaptureExceptionOccurred 回调,接收屏幕共享过程中的异常信息通知,从而可分析屏幕共享失败的原因。
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");
        }
    });
}

6 登录房间并开始推流

调用 loginRoom 接口,传入房间 ID 参数 “roomID” 和用户参数 “user”,登录房间。

调用 startPublishingStream 接口,传入流 ID 参数 “streamID”,向远端用户发送本端的音视频流。

// 创建用户
ZegoUser user = new ZegoUser("user1");

// 开始登录房间
engine.loginRoom("room1", user);
// 开始推流
engine.startPublishingStream("stream1");

至此,我们已完成采集屏幕数据并通过 ZEGO Express SDK 分享到远端的操作。

7 观看远端屏幕共享

完成以上步骤之后,其他用户可以使用 startPlayingStream 接口拉取屏幕共享流。

// 拉流播放,需传入发起屏幕共享的用户推流时所用的 streamID
engine.startPlayingStream(streamID, new ZegoCanvas(playView));

8 停止屏幕共享

用户可以调用 stopScreenCapture 接口停止共享。

engine.stopScreenCapture();

Previous

视频采集旋转

Next

水印和截图