FFmpeg AVDictionary结构体使用

简介:

简介
AVDictionary是FFmpeg的键值对存储工具,FFmpeg经常使用AVDictionary设置/读取内部参数

使用
avformat_open_input和avformat_find_stream_info函数都提供了AVDictionary参数,该参数可以在打开码流之前指定各种参数,比如:探测码流格式的时间,最大延时,超时时间,以及支持的协议的白名单等等

代码
AVInputFormat pInputFormat = NULL;
AVFormatContext 
pFormatContext = avformat_alloc_context();
AVDictionary *pOptions = NULL;
av_dict_set(&pOptions, "probesize", "4096", 0);
av_dict_set(&pOptions, "max_delay", "100", 0);//指定最大延时100毫秒
if (avformat_open_input(&pFormatContext, "", pInputFormat, &pOptions) < 0)

类似的也可以通过指定pFormatContext的参数来指定探测数据格式的数据大小和最大的延时
pFormatContext->probesize = 4 *1024;
pFormatContext->max_delay = 100;

问题
实际上通过设置探测码流格式的时间以及码流数据的大小,一定程度上,减少了探测的时间,但是也会导致探测码流格式失败,因此这种方式仅用于码流格式不明确的时候,要求点播延时不苛刻的情况下
通过设置了AVDictionary的max_delay参数值无效,并且pFormatContext->max_delay也设置无效

参考
http://blog.csdn.net/encoder1234/article/details/54582676



     本文转自fengyuzaitu 51CTO博客,原文链接:http://blog.51cto.com/fengyuzaitu/2053017,如需转载请自行联系原作者

相关文章
|
4月前
|
存储 编解码 索引
了解FFmpeg音频通道布局结构:AVChannelLayout结构体解析
了解FFmpeg音频通道布局结构:AVChannelLayout结构体解析
171 1
|
4月前
|
存储 缓存 编解码
FFmpeg常用结构体分析
FFmpeg常用结构体分析
51 0
|
4月前
|
编解码 网络协议 API
ffmpeg命令行工具源码之结构体分析1-命令行参数(未完结,持续更新)
ffmpeg作为多媒体文件转换工具,至少需要有一个要转换的输入文件信息(不仅仅是普通文件,还可以是摄像头设备,网络流等),和通常至少需要一个输出格式的文件(输出文件不仅仅指普通的文件,网络协议比如RTP协议,RTSP协议都可以理解为输出文件),ffmpeg的文件的转换过程主要由以下几个流程 (1)解封装 (2)解码 (3)过滤器 (4)编码 (5)封装 因此ffmpeg工具涉及的结构体主要就从这几个方面来说明这些结构体的含义。
66 0
|
11月前
[笔记]音视频学习之ffmpeg实践《一》常用结构体及裁剪画面思路(下)
[笔记]音视频学习之ffmpeg实践《一》常用结构体及裁剪画面思路(下)
|
11月前
|
存储 数据格式
[笔记]音视频学习之ffmpeg实践《一》常用结构体及裁剪画面思路(上)
[笔记]音视频学习之ffmpeg实践《一》常用结构体及裁剪画面思路
|
存储 Android开发 索引
【Android FFMPEG 开发】FFMPEG 获取 AVStream 音视频流 ( AVFormatContext 结构体 | 获取音视频流信息 | 获取音视频流个数 | 获取音视频流 )
【Android FFMPEG 开发】FFMPEG 获取 AVStream 音视频流 ( AVFormatContext 结构体 | 获取音视频流信息 | 获取音视频流个数 | 获取音视频流 )
249 0
|
编解码 缓存
FFMPeg代码分析:AVFrame结构体及其相关的函数
AVFrame结构体保存的是解码后和原始的音视频信息。AVFrame通过函数av_frame_alloc()初始化,该函数仅仅分配AVFrame实例本身,而没有分配其内部的缓存。
1095 0