目录
-
参考
-
lswr功能介绍
-
lswr使用说明
-
示例代码
\1. 参考
\2. lswr功能介绍 FFmpeg中重采样的功能由libswresample(后面简写为lswr)提供。 lswr提供了高度优化的转换音频的采样频率、声道格式或样本格式的功能。 功能说明:
-
采样频率转换:对音频的采样频率进行转换的处理,例如把音频从一个高的44100Hz的采样频率转换到8000Hz。从高采样频率到低采样频率的音频转换是一个有损的过程。API提供了多种的重采样选项和算法。
-
声道格式转换:对音频的声道格式进行转换的处理,例如立体声转换为单声道。当输入通道不能映射到输出流时,这个过程是有损的,因为它涉及不同的增益因素和混合。
-
样本格式转换:对音频的样本格式进行转换的处理,例如把s16的PCM数据转换为s8格式或者f32的PCM数据。此外提供了Packed和Planar包装格式之间相互转换的功能,Packed和Planar的区别见FFmpeg中Packed和Planar的PCM数据区别。
此外,还提供了一些其他音频转换的功能如拉伸和填充,通过专门的设置来启用。 3. lswr使用说明 重采样的处理流程:
-
创建上下文环境:重采样过程上下文环境为SwrContext数据结构。
-
参数设置:转换的参数设置到SwrContext中。
-
SwrContext初始化:swr_init()。
-
分配样本数据内存空间:使用av_samples_alloc_array_and_samples、av_samples_alloc等工具函数。
-
开启重采样转换:通过重复地调用swr_convert来完成。
-
重采样转换完成, 释放相关资源:通过swr_free()释放SwrContext。
下面是示例程序的一个流程图:
函数说明:
-
swr_alloc() :创建SwrContext对象。
-
av_opt_set_*():设置输入和输出音频的信息。
-
swr_init(): 初始化SwrContext。
-
av_samples_alloc_array_and_samples:根据音频格式分配相应大小的内存空间。
-
av_samples_alloc:根据音频格式分配相应大小的内存空间。用于转换过程中对输出内存大小进行调整。
-
swr_convert:进行重采样转换。
3.1 创建上下文环境 重采样过程上下文环境为SwrContext数据结构(SwrContext的定义没有对外暴露)。 创建SwrContext的方式有两种:
-
swr_alloc() : 创建SwrContext之后再通过AVOptions的API来设置参数。
-
swr_alloc_set_opts():在创建SwrContext的同时设置必要的参数。
两个函数的定义如下:
struct SwrContext* swr_alloc() struct SwrContext* swr_alloc_set_opts(struct SwrContext * s, //如果为NULL则创建一个新的SwrContext,否则对已有的SwrContext进行参数设置 int64_t out_ch_layout, //输出的声道格式,AV_CH_LAYOUT_* enum AVSampleFormat out_sample_fmt, int out_sample_rate, int64_t in_ch_layout, enum AVSampleFormat in_sample_fmt, int