zoukankan      html  css  js  c++  java
  • 音视频解码流程

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

    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函数。

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

  • 相关阅读:
    初识计算机
    前端html css
    mysql高级
    mysql多表查询
    mysql数据库查询
    mysql表关系
    mysql数据类型
    mysql数据库介绍
    异步回调 协程
    GIL-全局解释器锁
  • 原文地址:https://www.cnblogs.com/ranyang/p/14901534.html
Copyright © 2011-2022 走看看