#pragma implementation "wave.h"
#endif
+#include <wx/setup.h>
+
+#if wxUSE_WAVE
+
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#include "wx/file.h"
#include "wx/wave.h"
+//-----------------------------------------------------------------
+// wxWave
+//-----------------------------------------------------------------
wxWave::wxWave()
- : m_waveLength(0), m_isResource(FALSE), m_waveData(NULL)
+ : m_waveData(NULL), m_waveLength(0), m_isResource(FALSE)
{
}
wxWave::wxWave(const wxString& sFileName, bool isResource)
- : m_waveLength(0), m_isResource(isResource), m_waveData(NULL)
+ : m_waveData(NULL), m_waveLength(0), m_isResource(isResource)
{
- Create(sFileName, isResource);
+ Create(sFileName, isResource);
}
-wxWave::wxWave(int size, const byte* data)
- : m_waveLength(0), m_isResource(FALSE), m_waveData(NULL)
+wxWave::wxWave(int size, const wxByte* data)
+ : m_waveData(NULL), m_waveLength(0), m_isResource(FALSE)
{
- Create(size, data);
+ Create(size, data);
}
wxWave::~wxWave()
{
- Free();
+ Free();
}
bool wxWave::Create(const wxString& fileName, bool isResource)
{
- Free();
+ Free();
- if (isResource)
- {
- // todo
-
- return (m_waveData ? TRUE : FALSE);
- }
- else
- {
- m_isResource = FALSE;
+ if (isResource)
+ {
+ // todo
+ return (m_waveData ? TRUE : FALSE);
+ }
+ else
+ {
+ m_isResource = FALSE;
- wxFile fileWave;
- if (!fileWave.Open(fileName, wxFile::read))
- return FALSE;
+ wxFile fileWave;
+ if (!fileWave.Open(fileName, wxFile::read))
+ {
+ return FALSE;
+ }
- m_waveLength = (int) fileWave.Length();
+ m_waveLength = (int) fileWave.Length();
- m_waveData = new byte[m_waveLength];
- if (!m_waveData)
- return FALSE;
+ m_waveData = new wxByte[m_waveLength];
+ if (!m_waveData)
+ {
+ return FALSE;
+ }
- fileWave.Read(m_waveData, m_waveLength);
+ fileWave.Read(m_waveData, m_waveLength);
- return TRUE;
- }
+ return TRUE;
+ }
}
-bool wxWave::Create(int size, const byte* data)
+bool wxWave::Create(int size, const wxByte* data)
{
- Free();
- m_isResource = FALSE;
- m_waveLength=size;
- m_waveData = new byte[size];
- if (!m_waveData)
- return FALSE;
+ Free();
+ m_isResource = FALSE;
+ m_waveLength=size;
+ m_waveData = new wxByte[size];
+ if (!m_waveData)
+ {
+ return FALSE;
+ }
- for (int i=0; i<size; i++) m_waveData[i] = data[i];
- return TRUE;
+ for (int i=0; i<size; i++) m_waveData[i] = data[i];
+
+ return TRUE;
}
bool wxWave::Play(bool async, bool looped)
{
- if (!IsOk())
- return FALSE;
+ if (!IsOk()) return FALSE;
- int dev=OpenDSP();
- if(dev<0)
- return FALSE;
+ int dev = OpenDSP();
+
+ if (dev<0) return FALSE;
- ioctl(dev,SNDCTL_DSP_SYNC,0);
+ ioctl(dev,SNDCTL_DSP_SYNC,0);
- bool play=TRUE;
- int i,l=0;
- do
+ bool play=TRUE;
+ int i,l=0;
+ do
{
- i= (int)((l+m_DSPblkSize) < m_sizeData ? m_DSPblkSize : (m_sizeData-l));
- if ( write(dev,&m_data[l],i) != i )
- play=FALSE;
- l +=i;
- }while(play == TRUE && l<m_sizeData);
-
-
- close(dev);
- return TRUE;
-
+ i= (int)((l+m_DSPblkSize) < m_sizeData ? m_DSPblkSize : (m_sizeData-l));
+ if ( write(dev,&m_data[l],i) != i )
+ {
+ play=FALSE;
+ }
+ l +=i;
+ } while (play == TRUE && l<m_sizeData);
+
+ close(dev);
+ return TRUE;
}
bool wxWave::Free()
{
- if (m_waveData)
+ if (m_waveData)
{
- delete[] m_waveData;
- m_waveData = NULL;
- m_waveLength = 0;
- return TRUE;
+ delete[] m_waveData;
+ m_waveData = NULL;
+ m_waveLength = 0;
+ return TRUE;
}
- return FALSE;
+ return FALSE;
}
typedef struct
unsigned long ulAvgBytesPerSec;
unsigned short uiBlockAlign;
unsigned short uiBitsPerSample;
-}WAVEFORMAT;
-
+} WAVEFORMAT;
#define MONO 1 // and stereo is 2 by wav format
#define WAVE_FORMAT_PCM 1
int wxWave::OpenDSP(void)
{
- wxString str;
WAVEFORMAT waveformat;
int dev=-1;
unsigned long ul;
memcpy(&waveformat,&m_waveData[FMT_INDEX+4],sizeof(WAVEFORMAT));
- str= wxString(m_waveData,4);
- if (str != "RIFF") return -1;
- str= wxString(&m_waveData[WAVE_INDEX],4);
- if (str != "WAVE") return -1;
- str= wxString(&m_waveData[FMT_INDEX],4);
- if (str != "fmt ") return -1;
- str= wxString(&m_waveData[FMT_INDEX+waveformat.uiSize+8],4);
- if(str != "data") return -1;
+ if (memcmp(m_waveData, "RIFF", 4) != 0)
+ return -1;
+ if (memcmp(&m_waveData[WAVE_INDEX], "WAVE", 4) != 0)
+ return -1;
+ if (memcmp(&m_waveData[FMT_INDEX], "fmt ", 4) != 0)
+ return -1;
+ if (memcmp(&m_waveData[FMT_INDEX+waveformat.uiSize+8], "data", 4) != 0)
+ return -1;
memcpy(&ul,&m_waveData[FMT_INDEX+waveformat.uiSize+12],4);
m_sizeData=ul;
if ((int)(m_sizeData+FMT_INDEX+waveformat.uiSize+16) != m_waveLength)
return TRUE;
}
+#endif