WinAPI: waveInUnprepareHeader - 清除由 waveInPrepareHeader 完成的准备


WINMMAPI MMRESULT WINAPI waveInUnprepareHeader(HWAVEIN hwi, LPWAVEHDR pwh, UINT cbwh);

提示:
设备写满缓冲区返回给程序后, 须调用此函数;
释放(GlobalFree)缓冲区前, 须调用此函数;
取消一个尚未准备的缓冲区将无效, 但函数返回 0
 
  


//声明:

WINMMAPI MMRESULT WINAPI waveInUnprepareHeader(HWAVEIN hwi, LPWAVEHDR pwh, UINT cbwh);
waveInUnprepareHeader(
hWaveIn: HWAVEIN; /* 设备句柄 */
lpWaveInHdr: PWaveHdr; /* TWaveHdr 结构的指针 */
uSize: UINT /* TWaveHdr 结构大小 */
): MMRESULT; /* 成功返回 0; 可能的错误值见下: */

MMSYSERR_INVALHANDLE = 5; /* 设备句柄无效 */
MMSYSERR_HANDLEBUSY = 12; /* 设备已被另一线程使用 */
WAVERR_STILLPLAYING = 33; /* 缓冲区还在队列中 */

//TWaveHdr 是 wavehdr_tag 结构的重定义
wavehdr_tag = record
lpData: PChar; /* 指向波形数据缓冲区 */
dwBufferLength: DWORD; /* 波形数据缓冲区的长度 */
dwBytesRecorded: DWORD; /* 若首部用于输入, 指出缓冲区中的数据量 */
dwUser: DWORD; /* 指定用户的32位数据 */
dwFlags: DWORD; /* 缓冲区标志 */
dwLoops: DWORD; /* 循环播放次数, 仅用于输出缓冲区 */
lpNext: PWaveHdr; /* 保留 */
reserved: DWORD; /* 保留 */
end;

//TWaveHdr 中的 dwFlags 的可选值:
WHDR_DONE = $00000001; /* 设备已使用完缓冲区, 并返回给程序 */
WHDR_PREPARED = $00000002; /* waveInPrepareHeader 或 waveOutPrepareHeader 已将缓冲区准备好 */
WHDR_BEGINLOOP = $00000004; /* 缓冲区是循环中的第一个缓冲区, 仅用于输出 */
WHDR_ENDLOOP = $00000008; /* 缓冲区是循环中的最后一个缓冲区, 仅用于输出 */
WHDR_INQUEUE = $00000010; /* reserved for driver */


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值