当前位置: 首页 > news >正文

腾讯云TRTC无UI集成——分享屏幕主流、辅流(Vue2+JS+TRTC无UI集成)

先阐述一下问题,在项目中用到腾讯云的TRTC,A端发布A1、A2两个视频源,在B端订阅A1、A2使用两个view进行播放渲染

问题主流视频源和辅流视频源渲染在同一view上,控制台报错

// 播放远端视频 TRTCService.js;
setRemoteVideo(view) {this.trtcSdk.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, (event) => {if (event.streamType === TRTC.TYPE.STREAM_TYPE_MAIN) {console.log("开启主流视频源", view);this.trtcSdk.startRemoteVideo({userId: event.userId,streamType: event.streamType,view,});} else if (event.streamType === TRTC.TYPE.STREAM_TYPE_SUB) {console.log("开启辅流视频源", view);this.trtcSdk.startRemoteVideo({userId: event.userId,streamType: event.streamType,view,});}});
}// vue组件中调用
this.setRemoteVideo(this.el_scan),
this.setRemoteVideo(this.el_other),

监听订阅远端视频事件里判断主流和辅流传不同的view实例,运行结果是主流和辅流视频渲染在同一个view上,控制台报错如下:
在这里插入图片描述
问题原因:

每次触发 REMOTE_VIDEO_AVAILABLE 事件时都会调用 startRemoteVideo 方法,但由于 on
事件监听器是全局的,每次调用 setRemoteVideo(view)
方法时,都会为同一事件添加一个新的监听器。因此,当触发该事件时,多个监听器会被执行,导致视频源被渲染在多个视图上

解决这个问题的步骤如下:

在 setRemoteVideo(view) 中移除旧的监听器: 每次调用 setRemoteVideo(view)时,先移除之前可能存在的监听器,防止重复监听
在事件监听器中判断 view 参数: 在触发事件时,根据传入的 view参数来区分主流视频源和辅流视频源,确保它们渲染到正确的视图上

代码如下:

setRemoteVideo(view) {// 移除之前的监听器,防止重复监听this.trtcSdk.off(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE);this.trtcSdk.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, (event) => {if (view === this.el_scan && event.streamType === TRTC.TYPE.STREAM_TYPE_MAIN) {console.log("开启主流视频源");this.trtcSdk.startRemoteVideo({userId: event.userId,streamType: event.streamType,view,});} else if (view === this.el_other && event.streamType === TRTC.TYPE.STREAM_TYPE_SUB) {console.log("开启辅流视频源");this.trtcSdk.startRemoteVideo({userId: event.userId,streamType: event.streamType,view,});}});
}

运行结果:
在这里插入图片描述

控制台正常输出,但是主流视频源和辅流视频源还是渲染在同一个view上

继续分析:

由于两次调用 setRemoteVideo(view) 时,view 参数在 TRTC SDK内部没有正确区分,导致最后一次调用覆盖了前一次调用的效果。因此,尽管控制台只输出一次,但实际上两个视频流都渲染在了同一个 view 上

继续尝试:

确保每个视频流都有独立的渲染逻辑: 将主流和辅流的处理逻辑分开,避免它们在同一个 view 上覆盖
使用不同的事件监听器或参数区分: 可以通过将主流和辅流的视频渲染逻辑完全分离,在不同的监听器中处理它们,确保每个流都使用独立的 view

代码如下:

setRemoteVideoMain(viewMain) {this.trtcSdk.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, (event) => {if (event.streamType === TRTC.TYPE.STREAM_TYPE_MAIN) {console.log("开启主流视频源");this.trtcSdk.startRemoteVideo({userId: event.userId,streamType: event.streamType,view: viewMain,});}});
}
setRemoteVideoSub(viewSub) {this.trtcSdk.on(TRTC.EVENT.REMOTE_VIDEO_AVAILABLE, (event) => {if (event.streamType === TRTC.TYPE.STREAM_TYPE_SUB) {console.log("开启辅流视频源");this.trtcSdk.startRemoteVideo({userId: event.userId,streamType: event.streamType,view: viewSub,});}});
}// 组件中调用
this.setRemoteVideoSub(this.el_scan),
this.setRemoteVideoMain(this.el_other),

完美解决问题,主流和辅流视频源渲染在指定的位置


http://www.mrgr.cn/news/16154.html

相关文章:

  • 关于redux的一点记录
  • Ajax day-01
  • Linux进程基本介绍,ps指令详解
  • RabbitMQ练习(Remote procedure call (RPC))
  • 解决警告【WARNING: Ignoring invalid distribution -xxx 】
  • 二叉树--递归遍历--层次遍历--非递归遍历--详解
  • 500Kg载重无线遥控履带式无人车技术详解
  • Python tuple元数据操作:提升你的数据处理能力
  • [Day 68] 區塊鏈與人工智能的聯動應用:理論、技術與實踐
  • cannot import name ‘greycomatrix‘ from ‘skimage.feature.texture‘ 解决方法
  • YoloV8实战:数据集制作|两种高效的Labelme转Yolo脚本|适用于YoloV5、V7、V8、V9、V10
  • 电子检测报告如何盖骑缝章?
  • 存储 IO 性能优化策略、方案与瓶颈分析
  • 学院个人信息|基于SprinBoot+vue的学院个人信息管理系统(源码+数据库+文档)
  • 你真的理解编程语言里的数据相等吗
  • JavaScript练习(一)
  • Python使用OpenCV识别图片人脸
  • 成都高温限电:当电动汽车「无电可充」
  • 【高中数学\基本不等式】已知a,b皆为正数,且2/(a+2)+1/(a+2b)=1,则a+b的最小值是多少,此时a等于几?
  • 如何打造免费体育馆场地预约系统?php vue技术实现,简易操作指南