如何利用 AVDictionary 配置参数

本文是我的 FFMPEG Tips 系列的第五篇文章,准备介绍下 ffmpeg 提供的一个非常好用的健值对工具:AVDictionary,特别是对于没有 map 容器的 c 代码,可以充分利用它来配置和定义播放器的参数,ffmpeg 本身也有很多 API 通过它来传递参数。

1.  AVDictionary 的用法简介

AVDictionary 所在的头文件在 libavutil/dict.h,其定义如下:

struct AVDictionary {  
    int count;  
    AVDictionaryEntry *elems;  
};

其中,AVDictionaryEntry 的定义如下:

typedef struct AVDictionaryEntry {  
    char *key;  
    char *value;  
} AVDictionaryEntry;

下面就用示例的方式简单介绍下用法

(1)创建一个字典


AVDictionary *d = NULL;

(2) 销毁一个字典


av_dict_free(&d);

(3)添加一对 key-value


av_dict_set(&d, "name", "jhuster", 0);
av_dict_set_int(&d, "age", "29", 0);

(4) 获取 key 的值


AVDictionaryEntry *t = NULL;

t = av_dict_get(d, "name", NULL, AV_DICT_IGNORE_SUFFIX);
av_log(NULL, AV_LOG_DEBUG, "name: %s", t->value);

t = av_dict_get(d, "age", NULL, AV_DICT_IGNORE_SUFFIX);
av_log(NULL, AV_LOG_DEBUG, "age: %d", (int) (*t->value));

(5) 遍历字典


AVDictionaryEntry *t = NULL;
while ((t = av_dict_get(d, "", t, AV_DICT_IGNORE_SUFFIX))) {
    av_log(NULL, AV_LOG_DEBUG, "%s: %s", t->key, t->value);
}

2.  ffmpeg 参数的传递

ffmpeg 中很多 API 都是靠 AVDictionary 来传递参数的,比如常用的:

int avformat_open_input(AVFormatContext **ps, const char *url, AVInputFormat *fmt, AVDictionary **options);

最后一个参数就是 AVDictionary,我们可以在打开码流前指定各种参数,比如:探测时间、超时时间、最大延时、支持的协议的白名单等等,例如:

AVDictionary *options = NULL;
av_dict_set(&options, “probesize”, “4096", 0);
av_dict_set(&options, “max_delay”, “5000000”, 0);

AVFormatContext *ic = avformat_alloc_context();
if (avformat_open_input(&ic, url, NULL, &options) < 0) {
    LOGE("could not open source %s", url);
    return -1;
}

那么,我们怎么知道 ffmpeg 的这个 API 支持哪些可配置的参数呢 ?

我们可以查看 ffmpeg 源码,比如 avformat_open_input 是结构体 AVFormatContext 提供的 API,在 libavformat/options_table.h 中定义了 AVFormatContext 所有支持的 options 选项,如下所示:

https://www.ffmpeg.org/doxygen/trunk/libavformat_2options__table_8h-source.html

同理,AVCodec 相关 API 支持的 options 选项则可以在 libavcodec/options_table.h 文件中找到,如下所示:

https://www.ffmpeg.org/doxygen/3.1/libavcodec_2options__table_8h_source.html

3.  小结

当然,我们也可以仿照 ffmpeg,给自己的核心结构体对象定义这样的 options 选项,这篇文章就不展开详述了。

  • 4
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
AVDictionary 结构体是 FFmpeg 中用于存储键值对的数据结构,常用于传递附加的选项参数AVDictionary 结构体中的每个元素都是一个 AVDictionaryEntry 结构体,包含一个键和一个值。 AVDictionary 结构体中的元素可以使用 av_dict_set 或 av_dict_parse_string 函数添加;可以使用 av_dict_get 函数获取指定键的值;也可以使用 av_dict_count 函数获取元素个数。 下面是一种遍历 AVDictionary 结构体中所有元素的方法,通过遍历 AVDictionaryEntry 结构体数组实现: ```c AVDictionary *dict = ...; // 获取到的 AVDictionary 结构体指针 AVDictionaryEntry *entry = NULL; while ((entry = av_dict_get(dict, "", entry, AV_DICT_IGNORE_SUFFIX))) { printf("%s=%s\n", entry->key, entry->value); } ``` 其中,av_dict_get 函数用于从 AVDictionary 结构体中获取指定键的元素,第二个参数传空字符串 "" 表示获取所有元素;第三个参数 entry 表示从哪个元素开始获取,初始值应该为 NULL;第四个参数 AV_DICT_IGNORE_SUFFIX 表示不区分大小写。每次遍历时,都会返回下一个元素的 AVDictionaryEntry 结构体指针,如果已经遍历到最后一个元素,则返回 NULL,结束遍历。 遍历完 AVDictionary 结构体后,可以使用 av_dict_free 函数释放结构体内存。 另外,如果只需要获取指定键的值,可以直接使用 av_dict_get_string 函数,它返回指定键的字符串值,如果键不存在则返回 NULL。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值