使用H5Stream开发实时监控系统

这些天在尝试使用RTSP协议(Real Time Streaming Protocol,实时流传输协议)来完成实时传输和显示摄像头画面的功能,毕竟海康威视的web控件对高版本Chrome不予支持,如果使用这一套技术的话,后续的系统就难以优化升级。而RTSP协议在市面上已经有一些H5的解决方案了,是一种发展可期的方案。

H5Stream

在网上搜索web直播/摄像头直播等关键词找到了H5Stream,这是一个可以基于Native H5 Video标签实现直播的解决方案。当然它也支持其他的RTMP/HLS等。

发流服务通过RTSP地址从摄像头采集视频,在代码中可以通过配置文件进行配置。

h5ss配置

配置好摄像头信息后,我们启动发流服务h5ss.bat,开始进行client端的调试。

在www目录下有一个demo.html,这是demo网页,打开该文件可以知道如何连接发流服务。

在Vue项目中应用H5Stream的方法如下:

(1)在static目录下新增这几个js(adapter.js,h5splayer.js,h5splayerhelper.js,platform.js),这些在demo中有提供。

(2)在index.html中引用这些js

h5ss配置

(3)在vue页面调用API

createH5Video() {
    let conf1 = {
        videoid: 'divPlugin',
        protocol: this.$store.state.config.H5_STREAM_SERVER_PROTOCOL,
        host: this.$store.state.config.H5_STREAM_SERVER_HOST,
        rootpath: '/',
        token: 'token1',
        hlsver: 'v1',
        session: 'c1782caf-b670-42d8-ba90-2342340ee83'
    }
    this.v1 = H5sPlayerCreate(conf1)
    this.v1.connect()
},
closeH5Video() {
    if (this.v1) {
        this.v1.disconnect()
        this.v1 = null
        $(".h5video").get(0).pause()
    }
}

运行代码,可以实时地看到摄像头画面!(打了码,哈哈)

通过H5Stream看到的摄像头画面
关注我

  • 3
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 65
    评论
要用 HTML5 编写实时水质监测系统网页,你需要结合 JavaScript 和 CSS 来实现。以下是一个简单的示例代码,可以帮助你入门 HTML5 实时数据展示: ```html <!DOCTYPE html> <html> <head> <title>实时水质监测</title> <style> /* 样式表 */ #data-table { border-collapse: collapse; margin-top: 20px; } #data-table th, #data-table td { border: 1px solid #ccc; padding: 5px; } #data-table th { text-align: left; background-color: #eee; } </style> </head> <body> <h1>实时水质监测</h1> <table id="data-table"> <tr><th>参数</th><th>数值</th><th>单位</th></tr> <tr><td>pH 值</td><td id="ph-value"></td><td></td></tr> <tr><td>溶解氧</td><td id="do-value"></td><td>mg/L</td></tr> <tr><td>浊度</td><td id="turbidity-value"></td><td>NTU</td></tr> </table> <script> // JavaScript 代码 function updateData() { // 在这里编写获取实时数据的代码 // 然后更新网页上的数据显示 document.getElementById('ph-value').innerHTML = '7.5'; document.getElementById('do-value').innerHTML = '8.6'; document.getElementById('turbidity-value').innerHTML = '2.3'; } // 每隔 3 秒钟更新一次数据 setInterval(updateData, 3000); </script> </body> </html> ``` 在这个示例中,使用了 HTML5 的表格标签 (`<table>`, `<tr>`, `<th>`, `<td>`) 来展示实时数据。CSS 样式表用于美化表格的样式。JavaScript 代码通过定时器 (`setInterval()`) 每隔一段时间调用一次 `updateData()` 函数,来更新数据显示。 在 `updateData()` 函数中,你需要编写获取实时数据的代码,并更新网页上的数据显示。例如,可以使用 AJAX 技术从后端服务器获取实时数据。 当你完成了代码的编写后,可以在浏览器中打开这个 HTML 文件,查看实时水质监测系统的网页效果。注意,这个示例中的数据仅作为演示,你需要根据实际的数据源和业务需求进行相应的修改和开发

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 65
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值