• 音视频解码流程


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

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

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

  • 相关阅读:
    Zk学习笔记——权限控制
    guava学习笔记
    Elasticsearch学习笔记——别名
    Kafka学习笔记——存储结构
    分布式协议——Paxos、Raft和ZAB
    图解 Java 中的数据结构及原理!
    牛逼哄哄的 Lambda 表达式,简洁优雅就是生产力!
    你必须了解Spring的生态
    盘点 35 个 Apache 顶级项目,我拜服了…
    前后端分离如何做权限控制设计?
  • 原文地址:https://www.cnblogs.com/ranyang/p/14901534.html
Copyright © 2020-2023  润新知