FFmpeg 之 AVFormat

1 描述

它是一个I/O 和muxing/demuxing库,处理各种媒体容器格式库,主要包括两大功能:demuxing ,如将一个媒体文件拆分成音视频流, muxing,如将音视频数据写入一个媒体文件中。同时它还具有I/O module 可支持各种协议,如文件,tcp,http等等。muing 由AVInputFormat 结构体去描述,相反地,demuxing 由AVOutputFormat 去描述。

AVFormatContext 它是整个AVFormat 的上下文, 所有有关demuxing/muxing 都包含这结构体中。其中最重要的三个成员是:

1 struct AVInputFormat *iformat;/ struct AVOutputFormat *oformat;//muxing/demuxing 上下文

2 AVStream **streams;//存在音视频流

3 AVIOContext *pb;//读取媒体数据。

2 解复用器 

       解复用器读取媒体文件,并将其分割成数据块(视频/音频/字幕),a packet 包含一个或者多个已编码音视频单元,通过avformat_open_input() 去打开这文件,通过av_read_frame() 去读取数据包,最后通过avformat_close_input去关闭清除。如下表为FFMPEG Demuxing 部分开出来的API ,其定义是在avformat.h 文件中,实现在utils.c 文件中。如下表为demuxing 部分开出的API。在avformat_open_input() 之后,也能读出一些mediainfo 信息,但是要获取更多更完整的mediainfo 信息需要通过avformat_find_stream_info(), 前者只会读取文件头,后者还会解码一些帧。

int av_read_frame(AVFormatContext *s, AVPacket *ptk)  这函数作用是得到stream 的下一帧,如果读取成功将返回0 ,失败或者流结束返回负值, 其中流结束返回的负值是AVERROR_EOF。

3 复用器

复用器接收AVPacket 数据,并将其写入到指定的容器格式,avformat_write_header() 用于写文件头,av_write_frame()/av_interleaved_write_frame() 写数据packet, av_write_tailer() 用于完成文件。

Muxers 以AVPackets 形式接收数据,并写入指定的容器格式。其API 定义与avformat.c,实现位于util.c 中.如下表为muxing 部分开出的API。

CSDN站内私信我,领取最新最全C++音视频学习提升资料,内容包括(C/C++Linux 服务器开发,FFmpeg webRTC rtmp hls rtsp ffplay srs

4 metadata信息

    metadata是描述媒体文件的一些特有信息,比如音乐专辑信息,艺术家等等。被允许在muxing/demuxing 去设置/获取。AVFormatContext,AVStream,AVChapter,和AVProgram         可通过AVDictionary API 设置获取。

5 I/O read/write

ffmpeg 不但可以读取本地文件,同时它还可以读取网络文件,市面上常见的流媒体协议它都支持(如rtmp,rtsp,http等)。同各种容器的媒体文件demuxers一样,不同的协议底层都需有相应的文件去实现,ffmpeg 有对各种协议进行封装,avio.h开出的API 我们可以无感的读取各种协议的数据,如果我们使用ffmpeg 去播放media 的话,关于I/O 操作API 我们都接触不到,因为ffmpeg 内部已经帮我们做好了。AVFormatContext 中有个AVIOContext 结构体,它里面增加I/O读取buff 的管理,在AVIOContext 中的URLContext 成员,对应的就是具体的文件协议,比如rtmp,http,file hls,tcp 等等。它们之间的关系如下图所示:

6 core functions

列出一些查询libavformat 功能,申请core结构体的API。

7 utility functions

  描述一些与muxing/demuxing 有关的一些工具函数。在实际编程中,av_dump_format()还是用的比较多的, 比如demux 编程中, 我们初始化程序后,通过av_dump_format() 获取获取当前media 的info ,还是检查是否有初始化成功。

猜你喜欢

转载自blog.csdn.net/m0_60259116/article/details/125008430