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

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

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

javascript 复制代码
// 播放远端视频 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参数来区分主流视频源和辅流视频源,确保它们渲染到正确的视图上

代码如下:

javascript 复制代码
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

代码如下:

javascript 复制代码
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),

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

相关推荐
打小就很皮...30 分钟前
HBuilder 发行Android(apk包)全流程指南
前端·javascript·微信小程序
插件开发2 小时前
免费插件集-illustrator插件-Ai插件-随机填色
ui·illustrator
dancing9993 小时前
cocos3.X的oops框架oops-plugin-excel-to-json改进兼容多表单导出功能
前端·javascript·typescript·游戏程序
萌萌哒草头将军4 小时前
🚀🚀🚀Prisma 发布无 Rust 引擎预览版,安装和使用更轻量;支持任何 ORM 连接引擎;支持自动备份...
前端·javascript·vue.js
书语时4 小时前
ES6 Promise 状态机
前端·javascript·es6
拉不动的猪4 小时前
管理不同权限用户的左侧菜单展示以及权限按钮的启用 / 禁用之其中一种解决方案
前端·javascript·面试
西陵4 小时前
前端框架渲染DOM的的方式你知道多少?
前端·javascript·架构
海的诗篇_5 小时前
前端开发面试题总结-JavaScript篇(一)
开发语言·前端·javascript·学习·面试
じ☆ve 清风°5 小时前
理解JavaScript中map和parseInt的陷阱:一个常见的面试题解析
开发语言·javascript·ecmascript
江城开朗的豌豆5 小时前
eval:JavaScript里的双刃剑,用好了封神,用不好封号!
前端·javascript·面试