webrtc 支持H265(三) 总结

文章探讨了如何在Web端通过ZLMediaKit和WASM实现H265视频流的解码与渲染,特别是在单向视频流场景中的应用。数据通道(datachannel)的稳定性和解码性能是关键考虑因素,SIMD优化和硬解码提供了性能提升的可能性。对于双向视频流和包含音频流的场景,文章提出了解决方案和挑战。

web端的解码及渲染的实现

在前面的文章中介绍了ZLMediaKit的修改方法,在web端的播放器可以参照这个实现,基于wasm H265播放器
基本思路就是通过emscripten将ffmpeg的编译成wasm,可以直接在浏览器中运行的软解码器。然后用webgl渲染出图像。

应用场景

单向视频流的场景

这是这个方案着重解决的场景。

webrtc datachannel(基于ZLMediaKit) + wasm解码 + webgl渲染。这种方案,非常适合单向视频流的应用场景,比如:web看摄像头。在这样的场景中,视频流是单向的,码流从摄像头到ZLMediaKit到浏览器并且没有音频。

但是方案的应用有两个需要考虑的问题:

datachannel通道的稳定性

稳定性是从传输大数据量和可靠性两个角度衡量。

datachannel是可以传输大数量的,并且也有可靠性保证:丢包重传和保证有序。为此我做了两个场景的测试:

  1. 内网测试:ZLMediaKit与rtmp推流端,web都部署在内网。web通过datachannel拉8M的H265码流,并没有出现过丢包(这里的丢包指的是datachannel可能不稳定而造成的数据丢弃,并非指网络丢包),也没有出现乱序。
  2. 外网测试:ZLMediaKit部署在外网,rtmp推流端和web部署在内网。web拉H265码流,根据云服务的带宽设置推流码率大小,只要码率值小于带宽,则并不会出现丢包和乱序(说明datachannel通道是有可靠性保证的)。

关于延迟,对于webrtc datachannel通道的延迟我并没有专门进行测试,但是在后续的播放器整体测试时,webrtc datachannel通道并没有引入不可接受的延迟。

解码性能

浏览器通过ffmpeg软解码,对于分辨率大,码流大的情况或多路视频时,还是会出现性能不足的情况。可以通过以下两种方式进行优化:

  • simd解码

simd介绍见这个链接 WebAssembly中的simd
在emscripten中通过msimd128编译选项进行了支持。
实测效果,simd比ffmpeg的软件解码方式,性能提高了一倍。

  • 硬解码

浏览器已经可以支持对H265的硬解码,但是有浏览器的版本限制。
在chrome 浏览器中可以通过webcodec的API来使用硬解码。
可以看下这个链接,chrome支持hevc硬编解码。

双向视频流的场景

我没有实际的测试经验,但是基于webrtc datachannel + wasm 编解码的方案应该是能走通的。首先data channel通道是支持双向流,稳定性也不错。编码性能方面可以通过simd编码或硬编码解决。

有音频流的场景

有音频流最大的难点是要做音视频同步,也意味着web端不再只是单纯的解码,渲染,回放。还需要与ZLMediaKit服务器交互时间同步信息(比如rtcp的sr包)。这种需求比单向视频流的场景复杂很多,并且大概率效果还不好(因为限制太多)。所以如果同时有音视频流场景,还是在服务端做转码,将H265转成H264,然后在web端通过webrtc实现音视频处理更好。

敬告:该系列的课程在抓紧录制更新中,敬请大家关注。敬告:本课程项目仅供学习参考,请不要直接商用,概不负责任何法律责任。 该系列的课程涉及:FFmpeg,WebRTC,SRS,Nginx,Darwin,Live555,等。包括:音视频、流媒体、直播、Android、视频监控28181、等。 我将带领大家一起来学习使用FFmpeg开发视频监控项目,并动手操练。具体内容包括: 一、视频监控的架构和流程二、FFmpeg4.3+SDL2+Qt5开发环境的搭建、FFmpeg的SDK编程回顾总结并操练四、SDL2.0的编程回顾总结并操练五、颜色空间转换RGB和YUV的原理与实战六、Qt5+FFmpeg本地摄像头采集预览实战七、代码封装:摄像头h264/5编码并存储八、Qt5+FFmpeg单路网络摄像头采集预览九、Qt5+FFmpeg单路网络摄像头采集预览录制会看十、onvif与GB/T-28181的简介  音视频与流媒体是一门很复杂的技术,涉及的概念、原理、理论非常多,很多初学者不学 基础理论,而是直接做项目,往往会看到c/c++的代码时一头雾水,不知道代码到底是什么意思,这是为什么呢?   因为没有学习音视频和流媒体的基础理论,就比如学习英语,不学习基本单词,而是天天听英语新闻,总也听不懂。 所以呢,一定要认真学习基础理论,然后再学习播放器、转码器、非编、流媒体直播、视频监控、等等。   梅老师从事音视频与流媒体行业18年;曾在永新视博、中科大洋、百度、美国Harris广播事业部等公司就职,经验丰富;曾亲手主导广电直播全套项目,精通h.264/h.265/aac,曾亲自参与百度app上的网页播放器等实战产品。  目前全身心自主创业,主要聚焦音视频+流媒体行业,精通音视频加密、流媒体在线转码快编等热门产品。  
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mo4776

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值