音频缓冲区——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
一般步骤: