上一篇我们介绍了如何打开文件读取帧,现在,我们需要将成功读取的帧解码出来,所以,这里我们就需要要到以下几个结构体:
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函数。
最后,我们画了一个流程图,可以方便大家更好的理解: