一. 說明
AVAudioFifo是FFmpeg提供的一個先入先出的音頻緩沖隊列。主要要以下幾個特點:
- 操作在樣本級別而不是字節級別。
- 支持多通道的格式,不管是planar還是packed類型。
- 當寫入一個已滿的buffer時會自動重新分配內存。
二. 主要函數
- av_audio_fifo_alloc(): 根據采樣格式、通道數和樣本個數創建一個AVAudioFifo。
- av_audio_fifo_realloc():根據新的樣本個數為AVAudioFifo重新分配空間。
- av_audio_fifo_write(): 將數據寫入AVAudioFifo。如果可用的空間小於傳入nb_samples參數AVAudioFifo將自動重新分配空間。
- av_audio_fifo_size(): 獲取當前AVAudioFifo中可供讀取的樣本數量。
- av_audio_fifo_read():從AVAudioFifo讀取數據。
av_audio_fifo_read()的聲明在libavutil/audio_fifo.h,如下所示。
/** * 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 **data, int nb_samples);
三. 參考鏈接
1. FFmpeg: Audio FIFO Buffer