因为业务需要,直播推流过程中,pcm的音频需要从48k采样率,重采样到44.1k,然后再编码程aac,封装成rtmp推送出去。这里只描述如何做pcm数据的重采样。
整个过程中,音频输入:PCM/S16/48000/2 重采样输出: PCM/S16/441000/2,每一帧输入是10ms的samples。
重采样的基本思路是,先用input和output audio格式,来初始化ffmpeg resample, 然后准备好input数据,和output buffer后调用swr_convert函数来做重采样,具体处理函数如下:
步骤1:定义基本的处理函数和相关结构体
#include <libswresample/swresample.h>
bool initAudioResampler(const Frame&);
void uninitAudioResampler();
bool audioResample(const Frame&);
struct SwrContext *m_audioSwrCtx; //音频处理context
uint8_t **m_audioSwrSamplesData; //音频重采样后输出缓冲器
int m_audioSwrSamplesLinesize; //
int m_audioSwrSampl