上篇文章讲了如何用最新的技术采集声卡和麦克风,但是在工作中通常需要进行重采样为(44100、FLTP),再进行推流,所以本篇是在上次的基础上完成了重采样,重采样的核心代码如下:
// audiocap.cpp : 定义控制台应用程序的入口点。
//
#include "stdafx.h"
#include "AudioCapT.h"
#include <conio.h>
extern "C"
{
#include <libavformat/avformat.h>
#include <libswscale/swscale.h>
#include <libswresample/swresample.h>
#include <libavutil/opt.h>
#include <libavutil/channel_layout.h>
#include <libavutil/samplefmt.h>
}
#include <iostream>
using namespace std;
#pragma comment(lib,"avformat.lib")
#pragma comment(lib,"avcodec.lib")
#pragma comment(lib,"avutil.lib")
#pragma comment(lib,"swscale.lib")
#pragma comment(lib,"swresample.lib")
bool FillFltpSample(double *dst, int nb_samples, int nb_channels, char * pPcmBuffer, int nPcmBufLen)
{
int nTotal = nb_samples*nb_channels * 4;
if (!dst || !pPcmBuffer)
return false;
memset(dst, 0, nb_samples*nb_channels * 4);
int nTmp = 0;
if (nTotal >= nPcmBufLen)
{
nTmp = nPcmBufLen;
}
else
{
nTmp = nTotal;
}
memcpy(dst, pPcmBuffer, nTmp);
return true;
}
int _tmain(int argc, _TCHAR* argv[])
{
int64_t src_ch_layout = av_get_d