当前位置: 首页 > news >正文

Qt/C++音视频开发79-采集websocket视频流/打开ws开头的地址/音视频同步/保存到MP4文件/视频回放

一、前言

随着音视频的爆发式的增长,各种推拉流应用场景应运而生,基本上都要求各个端都能查看实时视频流,比如PC端、手机端、网页端,在网页端用websocket来接收并解码实时视频流显示,是一个非常常规的场景,单纯的http-flv模式受限于最大6个通道同时显示,一般会选择ws-flv也就是websocket的flv视频流,这种突破了6个的限制,而且实时性很好,音视频也都有,264/265都支持,webrtc不支持265很恼火,现在这么多265摄像头,尽管webrtc实时性最好,但是不支持265这一点,就几乎少掉一大半用户,尤其是视频监控行业。

以前也就思考过,既然是264/265的视频流过来,收到后用ffmpeg直接解码应该就可以播放,受限于之前的认知有限,以为一定要一个打开的地址才行,比如ffmpeg中常规操作就是avformat_open_input中填入一个地址,这个地址可以是本地音视频文件,也可以是网络视频流等,反正要有一个地址才行。直到近期要解决如何采集ws://这种地址的视频流的时候,才彻底静下心来研究这一块。原来ffmpeg从ffmpeg2开始就一直有这个机制,并不是一定要地址的,也可以是内存中的数据,需要定义一个AVIOContext对象,然后将formatCtx->pb赋值就完事,那边通过avio_alloc_context的回调函数获取数据即可。你只需要打开websocket收到数据,往缓存接口存数据就好,ffmpeg在调用打开也好读取av_read_frame也好,都会从缓存数据中取数据,取到数据就去解码。也就是在原来的代码基础上,加上少量的几十行代码就好,整

http://www.lryc.cn/news/408089.html

相关文章:

  • 网络安全等级保护制度1.0与2.0的演进与变革
  • 多线程优化API请求:CountDownLatch与PriorityBlockingQueue的应用
  • 谷粒商城实战笔记-54-商品服务-API-三级分类-拖拽效果
  • AI大模型学习必备十大网站
  • Elasticsearch:Golang ECS 日志记录 - zap
  • 关于线性代数(考研)
  • 【java基础】spring springMVC springboot 的区别
  • 【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 开源项目热度排行榜(100分) - 三语言AC题解(Python/Java/Cpp)
  • 大模型算法面试题(十一)
  • CSS 基础知识
  • IntelliJ IDEA 和 Eclipse的区别
  • Ansible之playbook剧本编写(二)
  • 力扣第二十九题——两数相除
  • 解析三款热门的文献翻译工具:优势与使用指南
  • git 过滤LFS文件下载
  • 内存泄漏详解
  • 多角度解析高防CDN防御DDOS及CC攻击
  • (7) cmake 编译C++程序(二)
  • C语言系统调用linux文件系统
  • LeetCode142 环形链表 II
  • 逆向案例二十八——某高考志愿网异步请求头参数加密,以及webpack
  • WebKit的文本装饰艺术:CSS Text Decoration全解析
  • 【linux】Shell脚本三剑客之sed命令的详细用法攻略
  • 解析class字节码文件获取魔数和版本号
  • 技术文档总结----思维导图
  • 【iOS】—— retain\release实现原理和属性关键字
  • 这一文,关于Java泛型的点点滴滴 一
  • 微信小程序之调查问卷
  • 基于Qt的视频剪辑
  • electron 网页TodoList工具打包成win桌面应用exe