前言:
大家好,今天给大家分享的内容是关于平时在做音频编解码会遇到的一些问题,比如说:
这三个问题是最近和同行交流的时候,大家遇到的一些问题,有些朋友一开始,没有思路去解决这种问题!
其实大家在做这块的时候,注意把握整个音视频的整体流程,比如说,编码、音视频处理、解码,核心就是这三个点,出现了问题,就往这三个大的方向去考虑,到底哪块出了问题,然后再去细节处理!,这样的话,我们至少有一个解决问题的思路,对于这种显示播放遇到的问题!
同时,对于官方的mpp源码要去多研究,结合官方给的手册!ok,我这里就简单说这些,下面看具体的问题,希望大家以后遇到类似的问题,有自己的思路去解决问题.
一、解码播放失败:
问题点:
首先这里给大家播放这个h264视频文件失败的现象:
通过ffplay播放,会有提示没有pps,所以解码播放失败了,如果你用vlc播放的话,啥都没有,这种时候,你就蒙圈了,不知道啥情况,这里也可以用Elecard_streamEye这个软件去分析h264的码流结构,由于这个文件有问题,Elecard_streamEye也是不支持打开的!
所以问题点就出现你的编码端,这个时候,去修改编码端,就可以解决问题了!
二、解码播放出现条纹:
问题点:
经过分析h264的码流结构,也没有问题:
当时我给这位朋友提供的思路,是stride(跨距:这个的意思是图像存储时内存中每行像素所占用的空间)的问题,这里大家可以去学习一下这个跨距,在我们平时各种芯片平台写编码代码的时候,要特别注意这个内存对齐问题!后面这个问题就是stride的问题:
三、编码的时候,修改分辨率大小,没有反应:
问题点:
这个问题就很明显了,后面问题解决了,问题点出现在:
四、总结:
大家发现没,我举得三个问题,本质都是编码端出得问题,所以官方发的mpp代码流程写法,值得花时间研究和借鉴一下。
也欢迎大家后期有编解码问题,可以多多相互探讨交流,后期我也会分享更多关于这块得实际问题给大家!
最后:
对嵌入式音频开发感兴趣的朋友,可以加入星球来学习,课程内容说明如下:
ai识别加音视频推流实战项目进度,整个项目从7月份开始,前两部分的ai识别工程基本上已经讲解完了(还有人脸识别的工程代码会进行重新重构一篇),当然这里面等录制完了第三部分的音视频推流开发内容,还会对ai识别这部分做补充,比如说yolo或者ssd等算法模型的原理讲解,还有就是自己怎么去训练模型;目前已经开始在录制音视频推流开发的第三部分,已经录制了两个小节部分,第三部分的内容会多搞点,比如理论知识的讲解,然后再结合我们的推流代码工程,可以学习到mpp和ffmpeg,以及rtmp、srt等相关协议,还包括h264、h265的码流结构和编码结构等相关知识点,甚至还包括工作当中常遇见家的问题,比如说,音视频不同步的问题,同时最近又添加了最新的课程内容:
最新课程内容更新:
可以直接扫码加入星球:
最后感谢大家的支持哈,加入了星球的朋友,记得加我微信:tu18879499804,我拉大家进解答群!