ffmpeg多个不同帧率不同格式的视频合并

本文详细介绍了如何使用ffmpeg合并不同帧率和格式的视频,涉及到解码、编码过程,包括注册容器和CODEC、打开文件、提取流信息、解码编码等步骤,适合FFMPEG开发者参考。
摘要由CSDN通过智能技术生成

相同视频编码格式之间是很好合并的,只需要按照流程打开文件,然后一帧一帧的读取,连生成视频的参数都不需要变得,唯一需要的就是改下pts就好了但是这块我一般不会拷贝原有的视频流参数,因为那样时间戳不好控制,

不同编码格式的视频合并就需要先解码每一帧数据,解码成最原始的YUV格式,然后在编码成你想要的编码格式。这样几乎所有的数据都一样了

FFMPEG解码流程:
  1. 注册所有容器格式和CODEC: av_register_all()
  2. 打开文件: av_open_input_file()
  3. 从文件中提取流信息: av_find_stream_info()
  4. 穷举所有的流,查找其中种类为CODEC_TYPE_VIDEO
  5. 查找对应的解码器: avcodec_find_decoder()
  6. 打开编解码器: avcodec_open()
  7. 为解码帧分配内存: avcodec_alloc_frame()
  8. 不停地从码流中提取出帧数据: av_read_frame()
  9. 判断帧的类型,对于视频帧调用: avcodec_decode_video()
  10. 解码完后,释放解码器: avcodec_close()
  11. 关闭输入文件: avformat_close_input_file()
基本概念:
   编解码器、数据帧、媒体流和容器是数字媒体处理系统的四个基本概念。
首先需要统一术语:
    容器/文件(Conainer/File):即特定格式的多媒体文件。
    媒体流(Stream):指时间轴上的一段连续数据,如一段声音数据,一段视频数据或一段字幕数据,可以是压缩的,也可以是非压缩的,压缩的数据需要关联特定的编解码器。
    数据帧/数据包(Frame/Packet):通常,一个媒体流由大量的数据帧组成,对于压缩数据,帧对应着编解码器的最小处理单元。通常,分属于不同媒体流的数据帧交错复用于容器之中,参见交错。
    编解码器:编解码器以帧为单位实现压缩数据和原始数据之间的相互转换。
在FFMPEG中,使用AVFormatContext、AVStream、AVCodecContext、AVCodec及AVPacket等结构来抽象这些基本要素,它们的关系如上图所示:
AVCodecContext:
    这是一个描述编解码器上下文的数据结构,包含了众多编解码器需要的参数信息,如下列出了部分比较重要的域:
typedef struct AVCodecContext {
 / **
     *一些编解码器需要/可以像使用extradata Huffman表。
     * MJPEG:Huffman表
     * RV10其他标志
     * MPEG4:全球头(也可以是在比特流或这里)
     *分配的内存应该是FF_INPUT_BUFFER_PADDING_SIZE字节较大
     *,比extradata_size避免比特流器,如果它与读prolems。
     * extradata按字节的内容必须不依赖于架构或CPU的字节顺序。
     * - 编码:设置/分配/释放由libavcodec的。
     * - 解码:由用户设置/分配/释放。
     * /
    uint8_t *extradata;
    int extradata_size;
   / **
     *这是时间的基本单位,在条件(以秒为单位)
     *帧时间戳派代表出席了会议。对于固定fps的内容,
     *基应该1/framerate和时间戳的增量应该
     *相同的1。
     * - 编码:必须由用户设置。
     * - 解码:libavcodec的设置。
     * /
    AVRational time_base;
 
    enum CodecID codec_id;
 / **
     *的fourcc(LSB在前,所以“的ABCD” - >(“D”<< 24)(“C”<< 16)(“B”<< 8)+“A”)。
     *这是用来解决一些编码错误。
     *分路器应设置什么是编解码器用于识别领域中。
     *如果有分路器等多个领域,在一个容器,然后选择一个
     *最大化使用的编解码器有关的信息。
     *如果在容器中的编解码器标记字段然后32位大分路器应该
     *重新映射到一个表或其他结构的32位编号。也可选择新
     * extra_codec_tag+大小可以添加,但必须证明这是一个明显的优势
     *第一。
     * - 编码:由用户设置,如果没有则默认基础上codec_id将使用。
     * - 解码:由用户设置,将被转换成在初始化libavcodec的大写。
     * /
    unsigned int codec_tag;

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值