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

vue video重复视频 设置 srcObject 视频流不占用资源 减少资源浪费

 // 直接设置srcObject减少获取视频流:通过 captureStream() 方法从下方视频元素获取视频流。

// 设置 srcObject:将获取到的视频流设置为上方视频的 srcObject 减少资源浪费

// 获取到需要复制到的dom元素   
const firstVideoElement = proxy.$refs.firstVideo;
// 获取需要复制的视频流元素
const activeVideoElement = proxy.$refs[`videoRefs${index}`][0];
// 赋值给需要显示的dom
firstVideoElement.srcObject = activeVideoElement.captureStream();
onMounted(async () => {try {const { data } = await getCameraInfo(props.id);if (!data) return;// console.log("视频监控", data);streams.value = data;if (streams.value && streams.value.length > 0) {await nextTick();streams.value.forEach((stream, index) => {let videoElement = proxy.$refs["videoRefs" + index][0]; // 通过 ref 获取视频元素const webRtcServer = new WebRtcStreamer(videoElement, url);webRtcServer.connect(stream.rtspVideoUrl);webRtcServers.value.push(webRtcServer); // 存储 WebRtcStreamer 实例});// 监听 loadedmetadata 事件proxy.$refs["videoRefs0"][0].addEventListener('loadedmetadata', () => {const firstVideoElement = proxy.$refs.firstVideo;const activeVideoElement = proxy.$refs[`videoRefs0`][playNum.value];firstVideoElement.srcObject = activeVideoElement.captureStream();});// nextTick(() => {//     // 默认加载第一个视频//     const firstVideoElement = proxy.$refs.firstVideo;//     // const firstWebRtcServer = new WebRtcStreamer(firstVideoElement, url);//     // firstWebRtcServer.connect(streams.value[playNum.value].rtspVideoUrl);//     // webRtcServers.value.push(firstWebRtcServer);//     const activeVideoElement = proxy.$refs[`videoRefs${index}`][0];//     firstVideoElement.srcObject = activeVideoElement.captureStream();// });}} catch (error) {console.error('Failed to fetch camera info:', error);}
});

原视频流加载完成后,再复制流


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

相关文章:

  • 单片机之基本元器件的工作原理
  • Redis | 十大数据类型
  • 基于 Nginx 的 CDN 基础实现
  • 编译spring 6.2.2
  • PHP之hyperf学习笔记
  • 苹果可折叠iPad:2028年的科技盛宴?
  • Leetcode 221. 最大正方形 动态规划
  • MiniFilter文件过滤
  • 静态路由配置与调试——计算机网络实训day1
  • [QCustomPlot] 交互示例 Interaction Example
  • SAP-FICO 标准价格与移动平均价格
  • NLP中常见的分词算法(BPE、WordPiece、Unigram、SentencePiece)
  • 音频数据增强:提升音频信号质量的多种技术
  • Open WebUI 与 AnythingLLM 安装部署
  • Docker compose 使用 --force-recreate --no-recreate 控制重启容器时的行为
  • Python 的网页自动化工具 DrissionPage 介绍
  • 互联网架构变迁:从 TCP/IP “呼叫” 到 NDN “内容分发” 的逐浪之旅
  • 【没能解决】虚拟机不能进入图形界面问题
  • 安卓硬件加速hwui
  • js实现一个可以自动重链的websocket客户端
  • 【ASP.NET学习】ASP.NET MVC基本编程
  • LSKNet 训练测试 (在容器实例中)
  • 数值分析速成复习笔记
  • 【STM32】无源蜂鸣器播放音乐《千与千寻》,HAL库
  • QThread多线程详解
  • Android原生开发同一局域网内利用socket通信进行数据传输