HTML5 播放 RTSP 视频的实例代码(HTML5 播放 RTSP 视频的实例代码)
HTML5 播放 RTSP 视频的实例代码
HTML5 播放 RTSP 视频的实例代码目前大多数网络摄像头都是通过 RTSP 协议传输视频流的,但是 HTML 并不标准支持 RTSP 流。除了 Firefox 浏览器可以直接播放 RTSP 流之外,几乎没有其他浏览器可以直接播放 RTSP 流。Electron 应用是基于 Chromium 内核的,因此也不能直接播放 RTSP 流。
在借助一定工具的情况下,可以实现在 Web 页面上播放 RTSP 流。本文介绍的方法可以应用于传统 Web 应用和 Electron 应用中,唯一的区别是将 Electron 应用的主进程当作传统 Web 应用的服务器。
目前已有 RTSP 播放方案的对比
既然是做直播,就需要延迟较低。当摄像头掉线时,也应当有一定的事件提示。处于这两点,对目前已有的已经实现、无需购买许可证的 RTSP 播放方案进行对比(处于原理阶段的暂时不分析)。
我对这四种方式都进行了实现,整体效果最好的还是第4种方案,占用端口少,延迟低,渲染速度快,而且离线事件易于处理。
基于 flv.js 的 RTSP 播放方案
flv.js 是 Bilibili 开源的一款 HTML5 浏览器。依赖于 Media Source Extension 进行视频播放,视频通过 HTTP-FLV 或 WebSocket-FLV 协议传输,视频格式需要为 FLV 格式。
服务器端(主进程)
服务器端采用 express + express-ws 框架进行编写,当有 HTTP 请求发送到指定的地址时,启动 ffmpeg 串流程序,直接将 RTSP 流封装成 FLV 格式的视频流,推送到指定的 WebSocket 响应流中。
import * as express from "express"; import * as expressWebSocket from "express-ws"; import ffmpeg from "fluent-ffmpeg"; import webSocketStream from "websocket-stream/stream"; import WebSocket from "websocket-stream"; import * as http from "http"; function localServer() { let app = express(); app.use(express.static(__dirname)); expressWebSocket(app, null, { perMessageDeflate: true }); app.ws("/rtsp/:id/", rtspRequestHandle) app.listen(8888); console.log("express listened") } function rtspRequestHandle(ws, req) { console.log("rtsp request handle"); const stream = webSocketStream(ws, { binary: true, browserBufferTimeout: 1000000 }, { browserBufferTimeout: 1000000 }); let url = req.query.url; console.log("rtsp url:", url); console.log("rtsp params:", req.params); try { ffmpeg(url) .addInputOption("-rtsp_transport", "tcp", "-buffer_size", "102400") // 这里可以添加一些 RTSP 优化的参数 .on("start", function () { console.log(url, "Stream started."); }) .on("codecData", function () { console.log(url, "Stream codecData.") // 摄像机在线处理 }) .on("error", function (err) { console.log(url, "An error occured: ", err.message); }) .on("end", function () { console.log(url, "Stream end!"); // 摄像机断线的处理 }) .outputFormat("flv").videoCodec("copy").noAudio().pipe(stream); } catch (error) { console.log(error); } }
为了实现较低的加载时间,可以为 ffmpeg 添加如下参数:
- analyzeduration 可以降低解析码流所需要的时间
- max_delay 资料上写的具体作用不太记得了,效果没有 analyzeduration 明显
当然这个实现还比较粗糙。当有多个相同地址的请求时,应当增加 ffmpeg 的输出,而不是启动一个新的 ffmpeg 进程串流。
浏览器端(渲染进程)
示例使用 Vue 框架进行页面设计。
<template> <li> <video class="demo-video" ref="player"></video> </li> </template> <script> import flvjs from "flv.js"; export default { props: { rtsp: String, id: String }, /** * @returns {{player: flvjs.Player}} */ data () { return { player: null } }, mounted () { if (flvjs.isSupported()) { let video = this.$refs.player; if (video) { this.player = flvjs.createPlayer({ type: "flv", isLive: true, url: `ws://localhost:8888/rtsp/${this.id}/?url=${this.rtsp}` }); this.player.attachMediaElement(video); try { this.player.load(); this.player.play(); } catch (error) { console.log(error); }; } } }, beforeDestroy () { this.player.destory(); } } </script> <style> .demo-video { max-width: 480px; max-height: 360px; } </style>
效果展示
用 Electron 页面展示了 7 个 Hikvison NVR 的摄像头,可以实现低延迟,低 CPU 占用,无花屏现象。由于涉及保密,这里就不放截图了。
同样的方法我播放了 9 个本地 1080p 的视频《白鹿原》,可以看一下这个效果。
播放效果非常好,完全没有卡顿和花屏,CPU 占用率也不高。
示例代码仓库: WhuRS-FGis/html5-rtsp 示例代码仓库:
总结
以上所述是小编给大家介绍的HTML5 播放 RTSP 视频的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对开心学习网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
- html5自动轮播图代码(HTML5播放实现rtmp流直播)
- html5怎么设置左边input(HTML5中input输入框默认提示文字向左向右移动的示例代码)
- html5video怎么用(html5视频媒体标签video的使用方法及完整参数说明详解)
- html5入门布局(吃透移动端 Html5 响应式布局)
- html5的语法变化(详解HTML5.2版本带来的修改)
- html5怎么设置红色(详解HTML5如何使用可选样式表为网站或应用添加黑暗模式)
- js如何解决iphone异形屏适配(Html5适配iphoneX刘海屏的简单实现)
- html5做app流程(html5唤醒APP小记)
- html5支持video的视频格式(解决html5中的video标签ios系统中无法播放使用的问题)
- html5拖拽标签(Html5原生拖拽相关事件简介以及基础实现)
- html5基础知识入门(萌新HTML5 入门指南二)
- ih5如何点击按钮跳转至网页(HTML5跳转小程序wx-open-launch-weapp的示例代码)
- html5标签怎么做(html5用video标签流式加载的实现)
- html5隐藏数字(HTML5去掉输入框type为number时的上下箭头的实现方法)
- HTML5离线缓存
- 如何获取html5表单中的元素的值(html5 datalist 选中option选项后的触发事件)
- 商务笔记本电脑主要的特点是什么(推荐一款商务笔记本)
- 有谁买过三星S4这个手机怎么样现在多少钱啦 (三星s4是什么型号的手机)
- LG的新款手机有哪些(Lg手机最新款是什么型号,多少钱)
- 金立的手机有哪些智能机(金立智能手机的第一款智能机是什么型号呢)
- 魅族MX3和小米3怎么样小米3和魅族MX3对比(小米3和魅族MX3哪款手机更好)
- 现在哪家5g手机最好(两千元以内不超过2000元的5G手机这几款哪个性价比最高)
热门推荐
- sql server案例(SQL Server作业报错特殊案例分析)
- 反射中BindingFlags的值
- mysql发生系统错误(MySQL too many connections错误的原因及解决)
- dedecms添加板块(DedeCMS关键词替换问题较完美解决方法)
- python实现螺旋矩阵(Python3实现的旋转矩阵图像算法示例)
- HttpWebResponse类的属性和方法
- python3.x base64怎么加密解密(python3.x实现base64加密和解密)
- mysql新增字段语句(关于Mysql update修改多个字段and的语法问题详析)
- css怎么设计文字阴影(css实现动态阴影、蚀刻文本、渐变文本效果)
- tomcat docker 性能(Docker Nginx容器和Tomcat容器实现负载均衡与动静分离操作)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9