畅直播
  • iOS
  • Android : Java
  • macOS
  • Windows
  • Web
  • Flutter
  • 产品简介
    • 概述
    • 发布日志
    • 基本概念
    • 产品优势
    • 应用场景
    • 限制说明
    • 升级指南
  • 计费说明
  • 下载
  • 快速开始
  • 直播推流
  • 直播拉流
  • 通信能力
  • 房间能力
  • 音频能力
  • 视频能力
  • 直播能力
  • 其他能力
  • 最佳实践
  • 客户端 API
  • 服务端 API
  • 常用错误码
  • 常见问题
  • 文档中心
  • 畅直播
  • 直播推流
  • 屏幕共享推流

屏幕共享

更新时间:2024-01-02 18:48

功能简介

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

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

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

/Pics/Express/screen_share_scene_new.png

示例源码下载

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

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

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

前提条件

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

实现流程

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

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

/Pics/Express/screen_capture_android_new.jpeg

1 获取用户录制屏幕授权

在工程的 AndroidManifest.xml 文件中,增加屏幕录制的权限配置。

在录制屏幕前,会弹窗提示用户是否允许应用录制屏幕,需要用户手动授权。

  1. 屏幕录制功能依赖于前台服务保活,进入您项目的 “app/src/main” 目录,打开 “AndroidManifest.xml” 文件,添加 FOREGROUND_SERVICE 权限声明。

    <uses-permission android:name="android.permission.FOREGROUND_SERVICE"/>
  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;

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;

engine.updateScreenCaptureConfig(config);

5 监听屏幕共享回调通知

开发者需要监听 IZegoEventHandler 类中的 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);
        }
    });
}

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();
本篇目录