一、本节目标
继上节获取解封装的 AvPacket 数据包之后,我们知道 AvPacket 存储的都是编码后的数据,因此我们需要将数据包进行解码,从而得到原始的数据,而 FFmpeg 使用 AvFrame 这个数据结构来存储解码后的数据。
对于解码后的数据:
- 视频原始数据一般是用
yuv表示。 - 音频原始数据一般用
pcm表示。
而在开始之前,我们还是来回顾一下 FFmpeg 处理流的整个过程。
FFmeg 处理流程如下:
- 1、得到输入流,打开输入流
- 2、解封装格式->得到编码数据包 AvPacket
- 3、解码数据包->得到解码的原始数据 AvFrame
- 4、处理数据->例如滤镜处理,重采样,像素格式转化等
- 5、编码原始数据->得到编码后的数据
- 6、封装格式
- 7、得到输出文件
根据本节目标,我们可以知道,我们重点要了解的就是第 3 步,解码数据包得到 AvFrame 数据。
二、解码音视频的步骤
2.1、 获取解码器
- 0、注册编解码器
avcodec_register_all();
- 1、 获取解码器
AVCodec
因为音频和视频的解码器
AVCodec是不一样的,而在 FFmpeg 中每一个解码器都会对应的一个codec_id,我们可以通过这个 id 就可以获取对应的解码器了。当前除了通过codec_id获取之外,也可以通过name来获取,目前先不考虑这种方式。
下面来看一下如何获取:
//得到视音频解码器
AVCodec *audioCodec = avcodec_find_decoder(
avFormatContext->

最低0.47元/天 解锁文章
983

被折叠的 条评论
为什么被折叠?



