WinAPI: waveOutWrite - 向输出设备发送一个数据块
2008-02-20 22:20
489 查看
提示:
把数据缓冲区传给 waveOutWrite 之前, 必须使用 waveOutPrepareHeader 准备该缓冲区;
若未调用 waveOutPause 函数暂停设备, 则第一次把数据块发送给设备时即开始播放.
把数据缓冲区传给 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 } //举例:
相关文章推荐
- WinAPI: waveOutOpen - 打开波形输出设备
- WinAPI: waveInAddBuffer - 向波形输入设备发送一个输入缓冲区
- WinAPI: waveOutGetDevCaps - 查询输出设备的性能
- WinAPI: waveOutGetPlaybackRate - 获取输出设备当前的播放速度设置(默认速度值的倍数)
- WinAPI: waveOutGetPosition - 获取输出设备当前的播放位置
- WinAPI: waveOutGetNumDevs - 获取波形输出设备的数目
- WinAPI: waveOutSetPitch - 设置输出设备的音调设置(音高的倍数值)
- WinAPI: waveOutGetPitch - 获取输出设备当前的音调设置(音高的倍数值)
- WinAPI: waveOutMessage - 向波形输出设备发送一条消息
- WinAPI: waveOutGetPlaybackRate - 设置输出设备的播放速度(默认速度值的倍数)
- waveOutGetDevCaps - 查询输出设备的性能
- WinAPI: midiInAddBuffer - 向 MIDI 输入设备发送一个输入缓冲区
- WinAPI: midiOutLongMsg - 向输出设备发送一条系统专用的 MIDI 消息
- WinAPI: waveOutClose - 关闭设备
- WinAPI: midiOutMessage - 向 MIDI 输出设备发送一条消息
- WinAPI: waveOutPrepareHeader - 准备一个波形数据块用于播放
- WinAPI: waveOutGetVolume - 获取输出设备当前的音量设置
- WinAPI: waveOutGetID - 获取输出设备 ID
- WinAPI: waveOutRestart - 重新启动一个被暂停的输出设备
- WinAPI: waveOutGetVolume - 获取输出设备当前的音量设置