1 //-----------------------------------------------------------------------------
6 // Copyright (c) 1999-2000 Microsoft Corp. All rights reserved.
7 //-----------------------------------------------------------------------------
21 //-----------------------------------------------------------------------------
23 //-----------------------------------------------------------------------------
24 #define WAVEFILE_READ 1
25 #define WAVEFILE_WRITE 2
27 #define DSUtil_StopSound(s) { if(s) s->Stop(); }
28 #define DSUtil_PlaySound(s) { if(s) s->Play( 0, 0 ); }
29 #define DSUtil_PlaySoundLooping(s) { if(s) s->Play( 0, DSBPLAY_LOOPING ); }
32 #define SAFE_DELETE(p) { if(p) { delete (p); (p)=NULL; } }
33 #define SAFE_DELETE_ARRAY(p) { if(p) { delete[] (p); (p)=NULL; } }
34 #define SAFE_RELEASE(p) { if(p) { (p)->Release(); (p)=NULL; } }
36 //-----------------------------------------------------------------------------
37 // Name: class CWaveFile
38 // Desc: Encapsulates reading or writing sound data to or from a wave file
39 //-----------------------------------------------------------------------------
43 WAVEFORMATEX* m_pwfx; // Pointer to WAVEFORMATEX structure
44 HMMIO m_hmmio; // MM I/O handle for the WAVE
45 MMCKINFO m_ck; // Multimedia RIFF chunk
46 MMCKINFO m_ckRiff; // Use in opening a WAVE file
47 DWORD m_dwSize; // The size of the wave file
48 MMIOINFO m_mmioinfoOut;
50 BOOL m_bIsReadingFromMemory;
55 //WAVEFORMATEX* m_pwfx;
57 char* m_pResourceBuffer;
59 //BOOL m_bIsReadingFromMemory;
64 HRESULT writeMMIO( WAVEFORMATEX *pwfxDest );
70 HRESULT open( LPTSTR strFileName, WAVEFORMATEX* pwfx, DWORD dwFlags );
71 HRESULT openFromMemory( BYTE* pbData, ULONG ulDataSize, WAVEFORMATEX* pwfx, DWORD dwFlags );
74 HRESULT read( BYTE* pBuffer, DWORD dwSizeToRead, DWORD* pdwSizeRead );
75 HRESULT write( UINT nSizeToWrite, BYTE* pbData, UINT* pnSizeWrote );
79 WAVEFORMATEX* getFormat() { return m_pwfx; };