实时音视频 SparkRTC
实时音视频 SparkRTC
- 最新动态
- 服务公告
- 产品介绍
- 快速入门
- 用户指南
- 最佳实践
- API参考
- 客户端SDK参考
-
常见问题
- 产品咨询
- 计费购买
- Signature相关
- 录制相关
-
SDK使用
- 如何创建房间?
- 两台手机同时运行SparkRTC APP,为什么无法互通?
- 鉴权是如何生成的?在什么时候生成?
- onVideoStats、onAudioStatus、onSubStreamStats回调触发时为什么程序会崩溃?
- 为什么本端听筒能听到自己的声音?
- setExternalAudioCapture(音频自采集)、setExternalVideoCapture(视频自采集)、setExternalMediaFrameOutput(视频自渲染)能在进入房间后开启吗?
- SparkRTC是否支持设置镜像画面?
- SparkRTC音视频过程中的上下行码率、分辨率、丢包率、音频采样率等信息怎么获取?
- SparkRTC是否支持设置本地采集音量?是否支持设置每个远端用户的播放音量?
- enableLocalVideo和muteLocalVideo有什么区别?
- enableLocalAudioStream和muteLocalAudio有什么区别?
- SparkRTC是否支持对房间进行权限校验?
- 接入PC端是否支持屏幕分享功能?
- SparkRTC是否支持将本地视频文件分享到实时音视频中?
- SparkRTC是否支持单纯的实时音频?
- 一个房间里可以同时有多路屏幕分享吗?
- SparkRTC是否支持1080P?
- 是否支持视频画面截图功能?
- 播放背景音乐是否支持在线音乐?
- 同一个页面中,可以创建N个RTC对象,通过N个UserID,分别登录到N个房间吗?
- Web端用宽高设置的推流分辨率适用于所有浏览器吗?
- Web端SDK在使用过程中拔掉摄像头,摄像头列表里面的数据如何清除?
- Web端SDK可以获取当前音量大小吗?
- Web端支持监听远端离开房间吗?
- Web端通话过程中为什么会出现回声、杂音、噪声、声音小?
- Web端如何切换摄像头和麦克风?
- SparkRTC支持白板功能吗?
- 相同UserID支持同时进入多个房间吗?
- SparkRTC房间的生命周期是多久?
- SparkRTC多人视频通话支持蓝牙耳机吗?
- SparkRTC多人视频通话支持仅订阅2/3/4人音频吗?
- 指定窗口分享,当窗口大小变化时,视频流的分辨率会跟着变化吗?
- 视频通话支持悬浮窗、大小画面切换功能吗?
- 发送自定义消息接口能实现聊天室、弹幕等功能吗?
- 支持查询所有的UserID吗?
- Web SDK中的checkSystemRequirements接口为什么会调用异常?
- 问题排查
- 通用参考
链接复制成功!
屏幕分享
功能描述
屏幕共享用于在音视频会议中,把一个与会者的屏幕内容,以视频的方式分享给其他与会者。屏幕共享可以共享整个桌面,也可以共享某一个程序窗口。
实现屏幕共享
- 加入房间
参考接口调用流程中加入房间的时序图步骤加入房间。
- 创建并播放共享流
入会后调用isScreenShareSupported检测浏览器是否支持共享流。确认支持后,通过调用createStream创建共享流,通过调用setScreenProfile设置共享流的分辨率,通过调用initialize初始化共享流,通过调用play播放共享流,通过调用bindScreenAudio2RelatedStream设置是否绑定屏幕共享背景音乐至关联流对象。
示例代码如下:
// screenAudio 设置是否共享主流音频 let co = {screen: true , screenAudio: false} // 创建共享流 let localAuxStream = HRTC.createStream(co) // 设置共享流分辨率 localAuxStream.setScreenProfile('1080p') // 初始化共享流 localAuxStream.initialize() .then(() => { // 播放共享流 c${this.clientIndex}-aux 播放共享流的DOM元素 localAuxStream.play(`c${this.clientIndex}-aux`) localAuxStream.bindScreenAudio2RelatedStream(this.localStream, screenAudio)}) .catch((error) => { console.error(error) })
- 发布共享流
本地播放共享流后,通过调用publish发布本地共享流。
示例代码如下:
this.client.publish(localAuxStream) .then(() => {console.info(`发布共享流成功`)}) .catch((error) => { console.error(`发布共享流失败`, error) })
- 接收远端用户的共享流
收到远端用户开启共享流通知stream-added后,通过调用subscribe订阅远端用户的共享流,当共享流订阅成功会收到stream-subscribed回调通知,然后通过调用play在指定的窗口里播放接收到的远端用户的共享流。
示例代码如下:
this.client.on('stream-added', (event: any) => { // 流类型为共享流的话 if (event.stream.getType() === 'auxiliary') { // remoteAuxStream 远端共享流 let remoteAuxStream = event.stream this.client.subscribe(remoteAuxStream ) .then(() => {console.info(`订阅共享流成功`)}) .catch( (error) =>(console.info(`订阅共享流失败`))) }}) this.client.on('stream-subscribed', (event: any) => { // 流类型为共享流的话 if (event.stream.getType() === 'auxiliary') { // c${ clientIndex}-remoteAux 播放共享流的DOM元素 event.stream.play(`c${ clientIndex}-remoteAux`) } })
- 取消发布共享流
共享流发布后,可以通过调用unpublish取消共享流。
示例代码如下:
this.client.unpublish(localAuxStream) .then(() => {console.info(`取消发布共享流成功`)}) .catch((error) => { console.error(`取消发布共享流失败`, error) })
- 停止播放共享流
共享流发布后,可以通过调用close停止播放共享流,共享流停止成功后本地会收到screen-sharing-stopped回调信息。
示例代码如下:
localAuxStream.close() localAuxStream.on('screen-sharing-stopped', () => { console.log(`屏幕共享停止`) localAuxStream = null })
- 停止接收远端用户的共享流
远端用户的共享流取消发布后,本地自动取消订阅,同时会收到stream-removed回调消息。
示例代码如下:this.client.on('stream-removed', (event: any) => { if (event.stream.getType() === 'auxiliary') { remoteAuxStream = null } })
父主题: 实现音视频通话(Web)