位置: IT常识 - 正文

vue集成海康h5player实现播放(h5调用海康摄像头)

编辑:rootadmin
vue集成海康h5player实现播放 文章目录前言准备工作视频demo官方文档官方工具开源工具开始开发效果问题点前言

推荐整理分享vue集成海康h5player实现播放(h5调用海康摄像头),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:海康威视web插件,uniapp海康威视,海康 html,vue海康威视,vue集成海康威视nvr视频回放,vue集成海康web控制,vue集成海康威视nvr视频回放,vue海康威视,内容如对您有帮助,希望把文章链接给更多的朋友!

本篇章只针对官方提供个h5player工具,做播放和分屏demo。

当然本篇章也是针对已经接触了海康视频对接的开发者。

准备工作视频demo官方文档

API https://open.hikvision.com/docs/docId?productId=5c67f20bb254d61550c2f63e&version=%2F658c4efa2595486c9ff140401628ff41&curNodeId=39e50b5c0aa84b47995614c9a102b75f

官方工具

https://open.hikvision.com/download/5c67f20bb254d61550c2f63e?type=10&id=53a1d2fe6a6f4b34b7aaccd37cd9c73d

开源工具

Dplayer:https://dplayer.diygod.dev/,这个支持的格式也很多,不过需要MSE支持

开始开发vue集成海康h5player实现播放(h5调用海康摄像头)

代码比较简单,就直接上了,先看代码

<template> <div id="app"> <el-container> <el-row> <el-input v-model="code" placeholder="输入监控点编码" @change="onChangeCode"></el-input> <el-button @click="onSubmit">默认预览</el-button> <el-button @click="onTwoSubmit(2)">4分屏</el-button> <el-button @click="onTwoSubmit(4)">16分屏</el-button> <el-button @click="onTwoSubmit(8)">64分屏</el-button> </el-row> <el-row> <div id="player" style="width: 800px;height: 800px;"></div> </el-row> </el-container> </div></template>// 请求工具import http from '@/http/http2.js'// 官方提供的播放工具import '@/static/util/h5player.min.js'export default { name: 'hik', data () { return { // 监控点编码 code: '', // 播放器对象 player: null } }, mounted () {// 页面加载初始化 this.initPlayer() }, methods: { /** * 初始化播放器 */ initPlayer () { this.player = new window.JSPlugin({ // 需要英文字母开头 必填 szId: 'player', // 必填,引用H5player.min.js的js相对路径 szBasePath: './static/util', // 当容器div#play_window有固定宽高时,可不传iWidth和iHeight,窗口大小将自适应容器宽高 iWidth: 600, iHeight: 400, // 分屏播放,默认最大分屏4*4 iMaxSplit: 16, iCurrentSplit: 1, // 样式 oStyle: { border: '#343434', borderSelect: '#FFCC00', background: '#000' } }) }, /** * 获取取流连接 * @returns {*} */ getPreviewUrl () { let tempCode = '61077001001320000018' if (this.code) { tempCode = this.code } const param = { 'cameraIndexCode': tempCode, 'streamType': 0, 'protocol': 'ws', 'transmode': 1 }// 这里 return http.post('/ay-video-manage/video/monitor/getRealTimeMonitorVideo', param) }, /** * 播放 */ play (index) { const _this = this this.getPreviewUrl().then(res => { if (res.status !== 200) { _this.$message.warning('获取视频流失败!') return } let preUrl = res.data.data.url const param = { playURL: preUrl, // 1:高级模式 0:普通模式,高级模式支持所有 mode: 1 } // 索引默认0 if (!index) { index = 0 } _this.player.JS_Play(preUrl, param, index).then(() => { // 播放成功回调 console.log('播放成功') }, (err) => { console.log('播放失败') }) }) }, /** * 监控点更新 * @param data */ onChangeCode (data) { this.code = data this.play() }, /** * 默认预览 */ onSubmit () { this.play() }, /** * 分屏,这里我太懒了,就循环了一个视频流 */ onTwoSubmit (num) { const _this = this // 这里的分屏,是以列来算的,如果这里参数2,那么就是横竖两列,就是4格 this.player.JS_ArrangeWindow(num).then( () => { // 循环取流 for (let i = 0; i < num * num; i++) { _this.play(i) } }, e => { console.error(e) } ) } }}

这里用的js是海康工具里下的

下载之后,将/bin目录下的文件复制到项目static下,这个工具的说明文档(API)在上一层的doc下面

效果

问题点官方提供的js文件不止一个,在初始化和播放时都会调用其他的js文件,那么就存在一个路径问题,我这里将所有的js都放在了src同目录下的static下了,然后在src下,也有一个static目录,不过里面只放了一个h5player.min.js,这样在使用h5player.min.js时就能调用到其他js,在初始化播放器时,需要设置js的相对路径属性szBasePath,所有的js都会添加这个路径前缀海康视频,大部分是h264编码,但也会存在h265的视频编码,如果使用hls是播放不了h265编码格式的视频的,所有,需要找一个方式,那就是使用官方提供的这个h5playerrtsp和rtmp比较麻烦,我是不想考虑的

然后这是ws流的对视频流的支持情况

我是个业余的前端,有什么不对还望指出

本文链接地址:https://www.jiuchutong.com/zhishi/287166.html 转载请保留说明!

上一篇:Vue项目线上发布,都有缓存不生效怎么办?(vue项目上线教程)

下一篇:Narrenmuehle(愚人磨坊风车),德国Dülken (© dpa picture alliance/Alamy)(愚人二部曲)

  • 子公司把利润给母公司怎么做账
  • 计算应纳税所得额时 不得扣除支出有哪些
  • 营业账簿印花税怎么交
  • 应收利息增加会计分录
  • 财务毛利率是毛利率吗
  • 增值税属于会计科目的什么
  • 客户逾期付款
  • 通过扣缴义务人和综合申报哪个好
  • 房屋买卖终止协议
  • 车船税完税凭证号
  • 驾驶培训费可以报销吗
  • 分支机构企业所得税计提和缴纳数额不一致怎么办?
  • 以前年度已交增值税额
  • 客户给现金
  • 税务局开租赁发票
  • 差旅费未及时报销说明怎么写
  • 典当行的账务处理会计分录大全
  • 资产负债一并转让增值税
  • 个人取得偶然所得怎么交税
  • 以旧换新计税依据
  • 其他应收款需要本月合计吗
  • 印花税零申报逾期
  • 冲销货款应怎么记账
  • 工程收入和成本的区别
  • 生产性生物资产和消耗性生物资产有什么区别
  • php的运算符主要包括哪些?
  • wordpress添加css
  • 家属补助每月发多少钱
  • 美国宇航局视频
  • 瑞士·劳特布龙嫩小镇
  • 防伪码查一次还能查第二次吗
  • react by
  • 爱丽丝小镇在哪
  • YOLOv5网络结构组成
  • webpack配置publicpath
  • yolov4源码解读
  • 建筑企业其他应付款包含什么内容
  • mysql数据库外键约束怎么写
  • 外埠施工企业
  • 企业分配股权
  • 个体户税务分几种
  • 认缴怎么填
  • 一般纳税人收到的普票可以抵扣吗
  • 土地使用税是新征税吗
  • 盘盈盘亏的定义
  • 增值税进项税转出有哪些
  • 合作社注销麻烦吗
  • 普通发票开具红字发票后发票联怎么处理?
  • 合同终止已开发怎么办
  • 资本公积资本溢价怎么算
  • 资产减值哪些资产
  • 代收会计分录
  • 进项已抵扣,退货发票怎么处理
  • 以自营方式建造固定资产
  • 如何提取坏账准备
  • 2020公司年会奖品清单
  • 汽车费用包括哪些会计科目呢
  • mysql 备份方式
  • sql server中数据类型怎么用
  • win7历史记录在哪里
  • xp系统一直在启动界面怎么办
  • linux dicom
  • centos屏蔽ip
  • win7内存检测工具
  • win7系统本身会占用多少空间
  • 服务器双系统怎么安装
  • w8系统鼠标在哪里调
  • 如何优化资本结构
  • 直线画画
  • js显示时间并且之后秒数实时更新
  • 国际安卓应用市场
  • unity ui碰撞
  • 使用js如何创建元素
  • 支付给境外的特许权使用费
  • 云南人社医保缴费步骤
  • 即征即退什么时候确认收入
  • 成都水费查询系统
  • 济宁税务大厅上班时间
  • 江苏国税局官网
  • 房地产预缴土增值税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设