在C#中使用WASAPI(Windows Audio Services API)进行音频捕获,通常涉及使用NAudio
库,这是一个流行的.NET库,用于处理音频。以下是一个基本的示例,展示了如何使用NAudio从默认音频输入设备捕获音频:
首先,确保安装了NAudio库。你可以通过NuGet包管理器安装它。
然后,你可以使用以下代码来读取音频输入:
using System; using NAudio.Wave; class Program { static void Main() { // 获取默认音频输入设备 using (var reader = new AudioFileReader("default")) { // 读取音频数据 byte[] buffer = new byte[reader.WaveFormat.SampleRate * reader.WaveFormat.Channels * 2]; // 根据需要调整缓冲区大小 int bytesRead; while ((bytesRead = reader.Read(buffer, 0, buffer.Length)) > 0) { // 处理音频数据 // 例如,打印每个样本的值 for (int i = 0; i < bytesRead / 4; i++) // 假设是16位音频 { short sample = BitConverter.ToInt16(buffer, i * 4); Console.WriteLine(sample); } } } } }
注意:
AudioFileReader
类用于读取音频文件,但在这里我们用它来读取默认音频输入设备的实时音频流。你需要将"default"
替换为实际的音频设备名称,这可以通过WaveIn
类的DefaultInputDevice
属性获取。- 缓冲区大小应根据你的音频格式和性能需求进行调整。对于实时音频捕获,通常使用较小的缓冲区大小,如1024或2048个样本。
- 上述代码仅打印了每个样本的值。你可以根据需要处理这些数据,例如将其保存到文件、分析音频特性或实时应用音频效果。
- 请确保你的应用程序具有访问音频设备的权限,并且已正确配置音频捕获设备。
请注意,此示例适用于16位单声道的音频。如果你的音频是立体声的或者使用不同的位深度,你需要相应地调整代码中的缓冲区大小和处理逻辑。此外,对于更高级的音频处理任务,你可能需要深入了解WASAPI和NAudio库的具体用法。