提示:
循环是由 saveOutWrite 传递的 TWaveHdr 结构的 dwLoop 和 dwFlags 控制的;
dwFlags 的 WHDR_BEGINLOOP、WHDR_ENDLOOP 标识循环的开始和结束数据块;
在同一数据块上循环, 应同时指定这两个标志;
循环次数 dwLoops 应该在开始块上指定;
循环终止前, 组成循环体的块一定要播放完;
当无播放内容或循环设定失败时, 函数也能返回 0.
循环是由 saveOutWrite 传递的 TWaveHdr 结构的 dwLoop 和 dwFlags 控制的;
dwFlags 的 WHDR_BEGINLOOP、WHDR_ENDLOOP 标识循环的开始和结束数据块;
在同一数据块上循环, 应同时指定这两个标志;
循环次数 dwLoops 应该在开始块上指定;
循环终止前, 组成循环体的块一定要播放完;
当无播放内容或循环设定失败时, 函数也能返回 0.
//声明: waveOutBreakLoop( hWaveOut: HWAVEOUT {设备句柄} ): MMRESULT; {成功返回 0; 可能的错误值见下:} MMSYSERR_INVALHANDLE = 5; {设备句柄无效} MMSYSERR_HANDLEBUSY = 12; {设备已被另一线程使用} //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; {保留(给设备)}
//举例: