使用“捕捉缓冲区”
捕捉一个声音包括以下步骤:
1.通过调用 IDirectSoundCaptureBuffer8::Start 方法启动缓冲区。正规来说,你应该设置 DSCBSTART_LOOPING 作为dwFlags参数,这样这个缓冲区将持续运行而不是当到达缓冲区末尾后就停止。从输入设备上获取的音频数据从缓冲区起始处开始填充。
2.等待直到达到期望的数据量。一个决定什么时候捕捉指针到达特定的位置办法,参见 Capture Buffer Notification。
3.当达到足够的数据量时,通过调用IDirectSoundCaptureBuffer8::Lock方法锁定一部分捕捉缓冲区。
为了确保你试图锁定的内存区域不是那些将被用于捕捉的区域,你可以首先通过调用IDirectSoundCaptureBuffer8::GetCurrentPosition方法得到读指针的位置。
你把将要读取的内存块的大小和偏移量作为参数传给Lock方法。这个方法返回一个指向这个内存块起始地址的指针和这一块的大小。如果这块区域从缓冲区末尾环绕到起始处,那么将会返回两个指针,第一个指针用于这块区域的每一个部分。如果锁定的内存区域没有环绕则第二个指针为NULL。
4.使用由Lock方法返回的地址和块大小,从缓冲区中复制数据。
5.使用IDirectSoundCaptureBuffer8::Unlock方法对缓冲区解锁。
6.重复2~5步,直到你准备停止捕捉数据。然后调用IDirectSoundCaptureBuffer8::Stop方法。
查看其它:
导 言
1.枚举“捕捉设备”
2.创建“捕捉设备对象”
3.“捕捉设备”性能
4.创建一个“捕捉缓冲区”
5.“捕捉缓冲区”信息
6.“捕捉缓冲区”通知
7. “捕捉缓冲区”特效
8.使用“捕捉缓冲区”
9.写入到WAV文件
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述