FFmpeg音频重采样API(libswresample)

目录

  1. 参考
  2. lswr功能介绍
  3. lswr使用说明
  4. 示例代码

1. 参考

2. lswr功能介绍

FFmpeg中重采样的功能由libswresample(后面简写为lswr)提供。
lswr提供了高度优化的转换音频的采样频率、声道格式或样本格式的功能。

功能说明:

  • 采样频率转换:对音频的采样频率进行转换的处理,例如把音频从一个高的44100Hz的采样频率转换到8000Hz。从高采样频率到低采样频率的音频转换是一个有损的过程。API提供了多种的重采样选项和算法。
  • 声道格式转换:对音频的声道格式进行转换的处理,例如立体声转换为单声道。当输入通道不能映射到输出流时,这个过程是有损的,因为它涉及不同的增益因素和混合。
  • 样本格式转换:对音频的样本格式进行转换的处理,例如把s16的PCM数据转换为s8格式或者f32的PCM数据。此外提供了Packed和Planar包装格式之间相互转换的功能,Packed和Planar的区别见PCM音频数据 - 知乎

此外,还提供了一些其他音频转换的功能如拉伸和填充,通过专门的设置来启用。

3. lswr使用说明

重采样的处理流程:

  1. 创建上下文环境:重采样过程上下文环境为SwrContext数据结构。
  2. 参数设置:转换的参数设置到SwrContext中。
  3. SwrContext初始化:swr_init()。
  4. 分配样本数据内存空间:使用av_samples_alloc_array_and_samples、av_samples_alloc等工具函数。
  5. 开启重采样转换:通过重复地调用swr_convert来完成。
  6. 重采样转换完成, 释放相关资源:通过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的方式有两种:

  1. swr_alloc() : 创建SwrContext之后再通过AVOptions的API来设置参数。
  2. swr_alloc_set_opts():在创建SwrContext的同时设置必要的参数。

【CSDN文末扫码进君 羊,免费分享】资料包括《Andoird音视频开发必备手册+音视频学习视频+学习文档资料包+大厂面试真题+2022最新学习路线图》等等 

 

两个函数的定义如下:

struct SwrContext* swr_alloc()

struct SwrContext* swr_alloc_set_opts(struct 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值