音视频解码流程

上一篇我们介绍了如何打开文件读取帧,现在,我们需要将成功读取的帧解码出来,所以,这里我们就需要要到以下几个结构体:

AVCodecContext:这个结构是一个解码器上下文,跟上一篇的formatContext一样。

AVCodec:这个结构是解码器。

下面我就进行一个简单的解码过程讲解:

1、首先我们需要申明一个解码器上下文并初始化。利用avcodec_alloc_context3函数

2、初始完后,我们根据提供的编解码器的值填充编解码器上下文,利用avcodec_parameters_to_context函数将对应流的解码器上下文填充。

3、然后我们就需要找到对应的解码器,利用avcodec_find_decoder函数,返回的值用AVCodec 结构体保存。

4、现在我们就需要打开这个解码器了,利用avcodec-open2函数。

5、以上工作做完后,我们就要开始读取帧了。利用av_read_frame函数。将读取的packet利用avcodec_send_packet进行解码,一个packet可能对应多个frame,所以我们需要循环的avcodec_recieve_frame,直到读完。

6、当读完退出后,因为还有一些缓存帧的原因,我们还需要再进行一遍avcodec_send_packet和avcodec_recieve_frame,将最后的缓存帧也读出来。

7、当以上的工作做完后,我们关闭解码器和释放解码器上下文,这里要用到avcodec_close函数和avcodec_free_context函数。

最后,我们画了一个流程图,可以方便大家更好的理解:

原文地址:https://www.cnblogs.com/ranyang/p/14901534.html