【nginx 源码 udp】【face++源码】【直播源码图】ppapi 源码
1.海康大华等摄像头RTSP低延迟(小于500毫秒)网页播放完全解决方案!
海康大华等摄像头RTSP低延迟(小于500毫秒)网页播放完全解决方案!
在浏览器中实现播放RTSP实时视频流,需要考虑多种方案以实现低延迟、低成本的多路稳定播放。首先,nginx 源码 udp浏览器插件方案在IE及Chrome 以下版本的浏览器中是主流选择,使用ActiveX播放控件或NPAPI播放插件,可直接调用本地原生程序播放,充分利用硬件解码和硬件加速渲染,实现良好效果。VLC作为开源跨平台多媒体播放器,支持IE、face++源码Chrome及Firefox低版本浏览器插件,移动端兼容性也非常好。然而,此方案需要额外安装VLC客户端软件,并对某些场景不适用。
其次,先转码再转流方案需要架设视频流转码服务器,利用ffmpeg转码串流成RTMP,然后前端使用VideoJS播放Adobe Flash Player。然而,基于Chromium内核的浏览器自年起全面取消了对Flash Player的支持,VideoJS因此失效。直播源码图当前方案使用flv.js实现,要求服务端先把RTSP视频流转换为flv,然后通过Web Socket或WebRTC推送到前端,前端再转换为Video所支持的MP4播放。这种方案导致RTSP视频流需要经过两次转码,画面延迟时间大幅增加,且长期使用服务器端转码和转流对CPU、内存、网络带宽压力大,成本高,播放高分辨率视频流时经常出现花屏、卡顿现象。源码建站系统此方案要求浏览器支持流媒体扩展特性(MSE),无法利用本机硬件加速实现解码和渲染播放,适用于移动端网页播放。
第三,先转流再转码方案通过Streamedian公司的免插件播放器Html5 RTSP Player实现。此方案需要架设Web Socket视频流转发服务器,前端连接到服务器后,服务端不断转发RTSP视频流给前端JS处理库,后端库再转换为Video所支持的MP4播放。此方案不支持IE浏览器,画面延迟高达数秒,首屏显示慢,易刷源码无法利用本机硬件加速,CPU占用高,播放时存在花屏、卡顿现象,体验差。此方案要求浏览器支持流媒体扩展特性(MSE),适用于单源播放,多路播放时服务器压力大,且兼容性较差,不适合作为商业用途。
扩展程序方案,如基于Chrome浏览器的PPAPI插件技术的VXG RTSP Player,不适用于IE、Firefox等浏览器,且谷歌已宣布将在年6月终止对NaCl、PNaCl和PPAPI API的支持,无讨论价值。双内核方案,如采用Chrome扩展程序IETab实现,存在大规模自主可控部署难问题,IE内核环境下播放控件控制困难,IE兼容性差,用户体验差,维护升级麻烦。
最后,Wasm方案采用Chrome等高版本浏览器支持的Wasm标准技术,实现RTSP视频流通过ffmpeg的Wasm版软解码为Video支持的MP4播放。Wasm不支持硬件解码,多路播放时终端电脑的CPU和内存占用高,性能差。此方案适用于需要支持H编码的场景,要求浏览器支持流媒体扩展特性(MSE),实际应用案例较少。
升级方案集中在实现不转码并充分利用终端电脑硬件加速特性的外接系统。这种系统需要在浏览器网页中实现一个内嵌到网页中的播放窗口,前端可控制播放窗口,并随浏览器窗口操作联动。播放窗口为本地原生程序,采用高性能C++语言开发,利用硬件加速,前端通过Web Socket连接播放窗口并发送JSON命令控制播放。市场上已有类似实现的软件,如猿大师中间件,提供全兼容性,包括低版本Chrome和IE浏览器,提供了类似ActiveX控件的安全机制。某视频监控大厂发布的版本采用QT框架,联动效果差,程序包大,未提供前端自动升级和安全调用机制。免插件方案中,外接程序的安全性可通过验证并开放源代码打消顾虑,部署和升级压力小,整体效果优于IE中的ActiveX控件。
综上所述,本文提供了一个稳定可靠、兼容性好、低延迟且可同时稳定播放多路RTSP的低成本半开源技术方案,特别适用于高分辨率RTSP播放。选择技术实施方案时,需考虑满足客户刚性需求、降低总成本、保证兼容性和稳定性,并确保技术方案不会因浏览器升级而失效。此方案适用于机场、地铁站、交管局等场景,实现低延迟、低成本的多路稳定播放。