zoukankan      html  css  js  c++  java
  • ffmpeg AVPacket 解释常用函数

    AVPacket 结构体解释
    AVBUffer/ref *buf : AVPacket采用的是引用计数,每次 AVPacket的时候把引用加一。

    int64_t pts 显示时间, 计算方法 pts * num/den)

    int64_t   dts  解码时间  因为b帧 有前后依赖帧率,先解码可能后显示,所以ffmpeg解码时候

     按照dts 时间解码 ,按照pts来显示.

    uint8_t*data 是AVBUffer/ref *buf  里面分配的空间

    int size data大小

    常用函数
    AVPacket *av_packet_alloc(void);

    创建并初始化。会分配空间,只是AVPacket的对象空间。

    AVPacket *av_packet_clone(const AVPacket *src); 

    创建AVPacket 对象,并且将src的里面的buf 添加引用计数(类似于opencv的 mat),新创建的AVPacket的buf就引用src的,在音视频同步的时候,会增加解码的packet的引用,存入到packet的缓冲队列中。

    int av_packet_ref(AVPacket *dst, const AVPacket *src)

    将src的buffer引用手动添加到 dst中,这里的dst必须是初始化好的AVPacket对象

    av_packet_unref(AVPacket *pkt)

    同上面的相反,手动减少pkt的引用

    void av_packet_free(AVPacket  **pkt)

    清空pkt对象,会将内部相应的引用计数减一。

    void av_init_packet(AVPacket *pkt)  

    初始化pkt是定义好的对象。

    int av_packet_from_data(AVPacket *pkt, uint8_t *data, int size)

    手动为packet分配空间

    int av_copy_packet(AVPacket *dst, const AVPacket *src) 

    这里是全部拷贝,没有使用引用计数,新的ffmpeg版本已经弃用。

  • 相关阅读:
    PHP中的$_POST变量
    leetcode problem 32 -- Longest Valid Parentheses
    leetcode problem 31 -- Next Permutation
    leetcode problem 11 Container With Most Water
    leetcode problem 10 Regular Expression Matching(动态规划)
    leetcode problem 6 ZigZag Conversion
    leetcode problem (5) Longest Palindromic Substring
    leetcode problem (2-4)
    extern “C”的作用
    C++11中新特性之:unordered_map
  • 原文地址:https://www.cnblogs.com/lidabo/p/15042984.html
Copyright © 2011-2022 走看看