转自http://blog.csdn.net/leixiaohua1020/article/details/50534316
1、将PCM16LE双声道音频采样数据转换为PCM8音频采样数据
本程序中的函数可以通过计算的方式将PCM16LE双声道数据16bit的采样位数转换为8bit。函数的代码如下所示
下面的samplenum8_u=samplenum8+128语句是将-128到127的8bit有符号数值转换为0到255的8bit无符号数值
2、将从PCM16LE单声道音频采样数据中截取一部分数据
本程序中的函数可以从PCM16LE单声道数据中截取一段数据,并输出截取数据的样值。函数的代码如下所示。
每个采样值占用2字节空间
3、将PCM16LE双声道音频采样数据转换为WAVE格式音频数据
WAVE格式音频(扩展名为“.wav”)是Windows系统中最常见的一种音频。该格式的实质就是在PCM文件的前面加了一个文件头。本程序的函数就可以通过在PCM文件前面加一个WAVE文件头从而封装为WAVE格式音频。函数的代码如下所示。
初始化声道数为2,采样率为44100
fseek函数使用参考http://write.blog.csdn.net/postedit/52801107
就是把文件指针移到WAVE_FMT处。
WAVE_FMT结构体里面:
dwAvgBytePerSec是每秒所需字节数
pcmFMT.dwAvgBytesPerSec=pcmFMT.dwSamplesPerSec*sizeof(m_pcmData);这里的
上次是每次加2字节,把PCM数据放入fpout位置(可以得到数据的大小dwSize)
总大小要加上44字节,参考http://blog.csdn.net/qingkongyeyue/article/details/52840494