实时音视频
  • iOS
  • Android
  • macOS
  • Windows
  • HarmonyOS
  • Linux
  • Web : JavaScript
  • 小程序
  • Flutter
  • Electron
  • Unreal Engine
  • Unity3D
  • uni-app
  • React Native
  • Cocos Creator
  • 产品简介
  • 下载
  • 体验 App
  • 快速开始
    • 跑通示例源码
    • 集成 SDK
    • 实现视频通话
    • 场景化音视频配置
  • 通信能力
  • 房间能力
  • 音频能力
  • 视频能力
  • 直播能力
  • 其他能力
  • 播放器插件
  • 最佳实践
  • 客户端 API
  • 服务端 API
  • 常见错误码
  • 常见问题
  • 文档中心
  • 实时音视频
  • 视频能力
  • 自定义视频采集

自定义视频采集

更新时间:2024-03-11 18:25

功能简介

自定义视频采集,是指由开发者自行采集视频,向 ZEGO Express SDK 提供视频数据,并由 ZEGO Express SDK 进行编码推流的功能。

当开发者业务中出现以下情况时,推荐使用 SDK 的自定义视频采集功能:

  • 普通摄像头的采集无法满足需求。例如,包含了大量的原有业务。
  • 直播非摄像头数据。例如视频播放、屏幕分享、游戏直播等。
  • 使用第三方虚拟摄像头外部采集来做自定义美颜等视频预处理。

示例源码下载

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

相关源码请查看 “src/Examples/AdvancedVideoProcessing/CustomVideoCapture” 目录下的文件。

前提条件

使用步骤

需要推送自定义视频源的流:

  1. 在调用 createZegoStream 接口创建 ZegoLocalStream 流实例对象时,通过设置 “source” 参数来指定第三方数据源。
  2. 调用 startPublishingStream 推流。
  • 设置第三方媒体流

    //开始预览本地视频
    previewVideo.srcObject = mediaStream;
    const stream = await zg.createZegoStream({
        custom: {
            video: {
                source: mediaStream
            },
            audio: {
                source: mediaStream // 视频原声,也可以为其他音频源
            }
        }
    })
    //推流
    zg.startPublishingStream(idName, stream);
  • 设置第三方音视频

    • 第三方音视频目前暂不支持 Safari 浏览器推流,只支持拉流。

    • 自 Chrome 86 开始,推第三方音视频流时,如果本地音视频设置静音,拉流端将无法听到对应的声音。

    source 为 <video> 或 <audio> 对象时,从其指定的视频或音频源作为预览。

    //localVideo 为 <video> 对象
    const stream = await zg.createZegoStream({
      custom: {
          video: {
              source: localVideo
          },
          audio: {
              source: localAudio // 可以为视频原声,也可以为其他音频源
          }
      }
    })
    //推流
    zg.startPublishingStream(idName, stream);
本篇目录