两个可能的解决方案:
首先,如果你的目标Vista和起来,你可以使用新的Windows音频API来调整每个应用程序的音量。 ISimpleAudioVolume,IAudioEndpointVolume等...
如果这不合适,可以将WAV文件直接加载到内存中并修改样本。试试这个:
从磁盘读取WAV文件并将其存储到内存缓冲区中,然后将样本缩小。我将假定所讨论的WAV文件是16位立体声,带有未压缩(PCM)样本。立体声或单声道。如果不是这样,大部分情况都会消失。
作为读者的练习,我将WAV文件字节的读数留给内存:但是让我们从下面的代码开始,其中“ReadWavFileIntoMemory”是您自己的函数。
DWORD dwFileSize;
BYTE* pFileBytes;
ReadWavFileIntoMemory(szFilename, &pFileBytes, &dwFileSize);
在这一点上,pFileBytes的检查看起来类似以下内容:
RIFF....WAVEfmt ............data....
这是WAV文件头。 “数据”是音频采样块的开始。
寻找“数据”部分,并将“数据”后面的4个字节读入DWORD。这是包含音频样本的“数据”块的大小。样本数量(假定PCM 16位是这个数字除以2)。现在
// FindDataChunk is your function that parses the WAV file and returns the pointer to the "data" chunk.
BYTE* pDataOffset = FindDataChunk(pBuffer);