您的位置:首页 > 其它

WinAPI: waveOutWrite - 向输出设备发送一个数据块

2008-02-20 22:20 489 查看
提示:
把数据缓冲区传给 waveOutWrite 之前, 必须使用 waveOutPrepareHeader 准备该缓冲区;

若未调用 waveOutPause 函数暂停设备, 则第一次把数据块发送给设备时即开始播放.

//声明:
waveOutWrite(
hWaveOut: HWAVEOUT;     {设备句柄}
lpWaveOutHdr: PWaveHdr; {TWaveHdr 结构的指针}
uSize: UINT             {TWaveHdr 结构大小}
): MMRESULT;              {成功返回 0; 可能的错误值见下:}

MMSYSERR_INVALHANDLE = 5;  {设备句柄无效}
MMSYSERR_HANDLEBUSY  = 12; {设备已被另一线程使用}
WAVERR_UNPREPARED    = 34; {未准备数据块}

//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 }

//举例:
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: