随笔 - 63  文章 - 72  评论 - 951  阅读 - 140万 

使用“捕捉缓冲区”


捕捉一个声音包括以下步骤:

     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文件 

posted on   stg609  阅读(1896)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 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的设计模式综述
分享按钮
点击右上角即可分享
微信分享提示