音视频开发25 FFmpeg 音频重采样实战化思考前提 - AVAudioFifo 详细分析

音频缓冲区——AVAudioFifo


AVAudioFifo是FFmpeg提供的一个先入先出的音频缓冲队列。主要要以下几个特点:

操作在样本级别而不是字节级别。
支持多通道的格式,不管是planar还是packed类型。
当写入一个已满的buffer时会自动重新分配内存。

注意:

音频头文件 libavutil/audio_fifo.h


主要函数


av_audio_fifo_alloc(): 根据采样格式、通道数和样本个数创建一个AVAudioFifo。

/**
 * Allocate an AVAudioFifo.
 *
 * @param sample_fmt  sample format
 * @param channels    number of channels
 * @param nb_samples  initial allocation size, in samples
 * @return            newly allocated AVAudioFifo, or NULL on error
 */
AVAudioFifo *av_audio_fifo_alloc(enum AVSampleFormat sample_fmt, int channels,
                                 int nb_samples);


根据采样格式,声道数量,样本数量 分配一个 AVAudioFifo,

为什么需要这三个参数呢?我们知道,AVAudioFifo是一个放置 pcm数据的 缓存,说白了就是放置的pcm数据,存储pcm的方式是一个一个样本为单位存放的。


那么这就涉及到一个样本的大小是多少的问题了?因此要传入 音频格式,声道数量 ,因为可以 根据 音频格式,声道数量,就能计算出来一个样本的大小了。
那么最后一个nb_samples 是干啥的呢?实际上是一个预设值,也就是说,我们告诉ffmpeg,大约需要nb_samples个样本数量,但是如果这个预设值nb_samples我们设置的小了,怎么办呢?
实际上,我们在av_audio_fifo_write时候如果buffer不足时,能自动扩充。
可以参考av_audio_fifo_write 方法的源码 就可以看到这一点。


av_audio_fifo_realloc():根据新的样本个数为AVAudioFifo重新分配空间。

/**
 * Reallocate an AVAudioFifo.
 *
 * @param af          AVAudioFifo to reallocate
 * @param nb_samples  new allocation size, in samples
 * @return            0 if OK, or negative AVERROR code on failure
 */
av_warn_unused_result
int av_audio_fifo_realloc(AVAudioFifo *af, int nb_samples);


av_audio_fifo_write(): 将数据写入AVAudioFifo。如果可用的空间小于传入nb_samples参数AVAudioFifo将自动重新分配空间。

AVAudioFifo *af:给第一个参数af中写入数据,

void * const *data, 存入数据的起始指针

int nb_samples 存储多少个样本数量

/**
 * Write data to an AVAudioFifo.
 *
 * The AVAudioFifo will be reallocated automatically if the available space
 * is less than nb_samples.
 *
 * @see enum AVSampleFormat
 * The documentation for AVSampleFormat describes the data layout.
 *
 * @param af          AVAudioFifo to write to
 * @param data        audio data plane pointers
 * @param nb_samples  number of samples to write
 * @return            number of samples actually written, or negative AVERROR
 *                    code on failure. If successful, the number of samples
 *                    actually written will always be nb_samples.
 */
int av_audio_fifo_write(AVAudioFifo *af, void * const *data, int nb_samples);


av_audio_fifo_size(): 获取当前AVAudioFifo中可供读取的样本数量。

/**
 * Get the current number of samples in the AVAudioFifo available for reading.
 *
 * @param af  the AVAudioFifo to query
 * @return    number of samples available for reading
 */
int av_audio_fifo_size(AVAudioFifo *af);


av_audio_fifo_read():从AVAudioFifo读取数据。

/**
 * Read data from an AVAudioFifo.
 *
 * @see enum AVSampleFormat
 * The documentation for AVSampleFormat describes the data layout.
 *
 * @param af          AVAudioFifo to read from
 * @param data        audio data plane pointers
 * @param nb_samples  number of samples to read
 * @return            number of samples actually read, or negative AVERROR code
 *                    on failure. The number of samples actually read will not
 *                    be greater than nb_samples, and will only be less than
 *                    nb_samples if av_audio_fifo_size is less than nb_samples.
 */
int av_audio_fifo_read(AVAudioFifo *af, void * const *data, int nb_samples);


视频缓冲区


头文件:avfifo.h


一般步骤:


1、获得图像帧大小frame_size(av_image_get_buffer_size)


2、申请需要帧数的缓冲区(av_fifo_alloc_array)


3、进出缓冲区
 

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值