目录
- 参考
- lswr功能介绍
- lswr使用说明
- 示例代码
1. 参考
- [1] FFmpeg/Libswresample Documentation
- [2] FFmpeg/Libswresample Detailed Description
- [3] FFmpeg/doc/examples/resampling_audio.c
2. lswr功能介绍
FFmpeg中重采样的功能由libswresample(后面简写为lswr)提供。
lswr提供了高度优化的转换音频的采样频率、声道格式或样本格式的功能。
功能说明:
- 采样频率转换:对音频的采样频率进行转换的处理,例如把音频从一个高的44100Hz的采样频率转换到8000Hz。从高采样频率到低采样频率的音频转换是一个有损的过程。API提供了多种的重采样选项和算法。
- 声道格式转换:对音频的声道格式进行转换的处理,例如立体声转换为单声道。当输入通道不能映射到输出流时,这个过程是有损的,因为它涉及不同的增益因素和混合。
- 样本格式转换:对音频的样本格式进行转换的处理,例如把s16的PCM数据转换为s8格式或者f32的PCM数据。此外提供了Packed和Planar包装格式之间相互转换的功能,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的同时设置必要的参数。
【CSDN文末扫码进君 羊,免费分享】资料包括《Andoird音视频开发必备手册+音视频学习视频+学习文档资料包+大厂面试真题+2022最新学习路线图》等等
两个函数的定义如下:
struct SwrContext* swr_alloc()
struct SwrContext* swr_alloc_set_opts(struct