海康对接摄像头

1.前端 播放用ws 流,后台调用海康后台可以直接返回

2.前端参考vue项目中播放ws(Websocket协议)视频流_ws视频流如何播放-CSDN博客这个地址就行了

3.注意js引用是否正确

一定要是这个目录

4.引用js的地方

5.代码,工具类

复制代码
<template>
  <div id="player" style="width: 100%;height: 100%;"></div>
</template>

<script src="../../../../../public/js/h5player.min.js"></script>


<script>
export default {
  data() {
    return {
      player: null
    }
  },
  mounted() {
    // 例如一屏播放4个视频,写法如下
    this.initPlayer(2);
    let arr = ['ws://58.221.113.46:559/openUrl/CCuqAQ8','ws://58.221.113.46:559/openUrl/Gppck0w','ws://58.221.113.46:559/openUrl/pJXovNm','ws://58.221.113.46:559/openUrl/Kb4L9Nm'];
    arr.forEach((url, index) => {
      this.realplay(url, index);
    })
  },
  methods: {
    // 初始化
    initPlayer(num = 1) { // 设置分屏:1*1、2*2、3*3、4*4
      this.player = new JSPlugin({
        szId: 'player', // 父窗口id,需要英文字母开头 必填
        szBasePath: "js/", // 必填,与h5player.min.js的引用路径一致
        iMaxSplit: 4, // 分屏播放,默认最大分屏4*4
        openDebug: true,
        mseWorkerEnable: false,//是否开启多线程解码,分辨率大于1080P建议开启,否则可能卡顿
        bSupporDoubleClickFull: true,//是否支持双击全屏,true-双击是全屏;false-双击无响应
        oStyle: {
          borderSelect: '#343434', // 选中视频的边框颜色,默认选择第一个,颜色为#fc0
        }
      })
      this.player.JS_ArrangeWindow(num).then(
        () => { console.log(`arrangeWindow to ${num}x${num} success`) },
        e => { console.error(e) }
      )
      // 监听视频连接过程中出现的异常
      this.player.JS_SetWindowControlCallback({
        pluginErrorHandler(iWindIndex, iErrorCode, oError) {
          console.error(`监控窗口${iWindIndex}发生错误,错误码: ${iErrorCode},${oError}`);
        }
      });
    },
    // 预览
    realplay (playURL = '', index = 0) { // 设置第index(从0开始)个窗口的视频地址
      this.player.JS_SetTraceId(index, true);
      this.player.JS_Play(playURL, { playURL, mode: 0, keepDecoder: 0, token: '' }, index).then(
        () => {
          console.log('realplay success');
          this.player.JS_GetTraceId(index).then((id) => { console.log("traceid:", id) })
        },
        e => { console.error(e) }
      )
    },
  }
}
</script>
<style scoped lang="less">
/* 由于我的视频没有撑满整个容器,所以加了下面的样式,如果没遇到这种情况可以忽略。*/
// 设置2*2分屏时
/deep/#player {
  & > div, & > div > div > video {
    width: 100% !important;
    height: 100% !important;
  }
  & > div > div {
    width: 50% !important;
    height: 50% !important;
  }
}
/*
// 设置1*1分屏时
/deep/#player {
    & > div,
    & > div > div,
    & > div > div > video {
        width: 100% !important;
        height: 100% !important;
    }
}
*/
</style>

6.引用的地方

相关推荐
Howrun7772 小时前
VSCode烦人的远程交互UI讲解
ide·vue.js·vscode
JH30733 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_4 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble4 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
小迷糊的学习记录4 小时前
Vuex 与 pinia
前端·javascript·vue.js
较真的菜鸟4 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖4 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
利刃大大4 小时前
【Vue】Element-Plus快速入门 && Form && Card && Table && Tree && Dialog && Menu
前端·javascript·vue.js·element-plus
小毛驴8506 小时前
Vue 路由示例
前端·javascript·vue.js
qq_12498707536 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计