adapting to new sound file organization for osx
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@61916 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
48
Makefile.in
48
Makefile.in
@@ -11921,6 +11921,7 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS = \
|
||||
monodll_carbon_drawer.o \
|
||||
monodll_dataview_osx.o \
|
||||
monodll_carbon_dataview.o \
|
||||
monodll_sound_osx.o \
|
||||
monodll_carbon_sound.o \
|
||||
monodll_carbon_taskbar.o \
|
||||
monodll_hidjoystick.o
|
||||
@@ -11928,7 +11929,9 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS = \
|
||||
COND_TOOLKIT_OSX_COCOA___ADVANCED_PLATFORM_SRC_OBJECTS = \
|
||||
monodll_taskbarcmn.o \
|
||||
monodll_animateg.o \
|
||||
monodll_sound_osx.o \
|
||||
monodll_carbon_sound.o \
|
||||
monodll_core_sound.o \
|
||||
monodll_cocoa_aboutdlg.o \
|
||||
monodll_dataview_osx.o \
|
||||
monodll_cocoa_dataview.o \
|
||||
@@ -12097,6 +12100,7 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS_0 = \
|
||||
monolib_carbon_drawer.o \
|
||||
monolib_dataview_osx.o \
|
||||
monolib_carbon_dataview.o \
|
||||
monolib_sound_osx.o \
|
||||
monolib_carbon_sound.o \
|
||||
monolib_carbon_taskbar.o \
|
||||
monolib_hidjoystick.o
|
||||
@@ -12104,7 +12108,9 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS_0 = \
|
||||
COND_TOOLKIT_OSX_COCOA___ADVANCED_PLATFORM_SRC_OBJECTS_0 = \
|
||||
monolib_taskbarcmn.o \
|
||||
monolib_animateg.o \
|
||||
monolib_sound_osx.o \
|
||||
monolib_carbon_sound.o \
|
||||
monolib_core_sound.o \
|
||||
monolib_cocoa_aboutdlg.o \
|
||||
monolib_dataview_osx.o \
|
||||
monolib_cocoa_dataview.o \
|
||||
@@ -12367,6 +12373,7 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS_8 = \
|
||||
advdll_drawer.o \
|
||||
advdll_dataview_osx.o \
|
||||
advdll_carbon_dataview.o \
|
||||
advdll_sound_osx.o \
|
||||
advdll_carbon_sound.o \
|
||||
advdll_carbon_taskbar.o \
|
||||
advdll_hidjoystick.o
|
||||
@@ -12374,7 +12381,9 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS_8 = \
|
||||
COND_TOOLKIT_OSX_COCOA___ADVANCED_PLATFORM_SRC_OBJECTS_8 = \
|
||||
advdll_taskbarcmn.o \
|
||||
advdll_animateg.o \
|
||||
advdll_sound_osx.o \
|
||||
advdll_carbon_sound.o \
|
||||
advdll_core_sound.o \
|
||||
advdll_cocoa_aboutdlg.o \
|
||||
advdll_dataview_osx.o \
|
||||
advdll_cocoa_dataview.o \
|
||||
@@ -12449,6 +12458,7 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS_9 = \
|
||||
advlib_drawer.o \
|
||||
advlib_dataview_osx.o \
|
||||
advlib_carbon_dataview.o \
|
||||
advlib_sound_osx.o \
|
||||
advlib_carbon_sound.o \
|
||||
advlib_carbon_taskbar.o \
|
||||
advlib_hidjoystick.o
|
||||
@@ -12456,7 +12466,9 @@ COND_TOOLKIT_OSX_CARBON___ADVANCED_PLATFORM_SRC_OBJECTS_9 = \
|
||||
COND_TOOLKIT_OSX_COCOA___ADVANCED_PLATFORM_SRC_OBJECTS_9 = \
|
||||
advlib_taskbarcmn.o \
|
||||
advlib_animateg.o \
|
||||
advlib_sound_osx.o \
|
||||
advlib_carbon_sound.o \
|
||||
advlib_core_sound.o \
|
||||
advlib_cocoa_aboutdlg.o \
|
||||
advlib_dataview_osx.o \
|
||||
advlib_cocoa_dataview.o \
|
||||
@@ -18619,6 +18631,12 @@ monodll_sound_sdl.o: $(srcdir)/src/unix/sound_sdl.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@monodll_carbon_dataview.o: $(srcdir)/src/osx/carbon/dataview.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/osx/carbon/dataview.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@monodll_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@monodll_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@monodll_carbon_sound.o: $(srcdir)/src/osx/carbon/sound.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/osx/carbon/sound.cpp
|
||||
|
||||
@@ -18637,6 +18655,9 @@ monodll_sound_sdl.o: $(srcdir)/src/unix/sound_sdl.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_COCOA_USE_GUI_1@monodll_hidjoystick.o: $(srcdir)/src/osx/core/hidjoystick.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/osx/core/hidjoystick.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@monodll_core_sound.o: $(srcdir)/src/osx/core/sound.cpp $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_CXXFLAGS) $(srcdir)/src/osx/core/sound.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@monodll_cocoa_aboutdlg.o: $(srcdir)/src/osx/cocoa/aboutdlg.mm $(MONODLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONODLL_OBJCXXFLAGS) $(srcdir)/src/osx/cocoa/aboutdlg.mm
|
||||
|
||||
@@ -23347,6 +23368,12 @@ monolib_sound_sdl.o: $(srcdir)/src/unix/sound_sdl.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@monolib_carbon_dataview.o: $(srcdir)/src/osx/carbon/dataview.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/osx/carbon/dataview.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@monolib_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@monolib_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@monolib_carbon_sound.o: $(srcdir)/src/osx/carbon/sound.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/osx/carbon/sound.cpp
|
||||
|
||||
@@ -23365,6 +23392,9 @@ monolib_sound_sdl.o: $(srcdir)/src/unix/sound_sdl.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_COCOA_USE_GUI_1@monolib_hidjoystick.o: $(srcdir)/src/osx/core/hidjoystick.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/osx/core/hidjoystick.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@monolib_core_sound.o: $(srcdir)/src/osx/core/sound.cpp $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_CXXFLAGS) $(srcdir)/src/osx/core/sound.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@monolib_cocoa_aboutdlg.o: $(srcdir)/src/osx/cocoa/aboutdlg.mm $(MONOLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA_USE_GUI_1@ $(CXXC) -c -o $@ $(MONOLIB_OBJCXXFLAGS) $(srcdir)/src/osx/cocoa/aboutdlg.mm
|
||||
|
||||
@@ -31819,6 +31849,12 @@ advdll_wizard.o: $(srcdir)/src/generic/wizard.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@advdll_carbon_dataview.o: $(srcdir)/src/osx/carbon/dataview.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@ $(CXXC) -c -o $@ $(ADVDLL_CXXFLAGS) $(srcdir)/src/osx/carbon/dataview.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON@advdll_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@ $(CXXC) -c -o $@ $(ADVDLL_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA@advdll_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA@ $(CXXC) -c -o $@ $(ADVDLL_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON@advdll_carbon_sound.o: $(srcdir)/src/osx/carbon/sound.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@ $(CXXC) -c -o $@ $(ADVDLL_CXXFLAGS) $(srcdir)/src/osx/carbon/sound.cpp
|
||||
|
||||
@@ -31837,6 +31873,9 @@ advdll_wizard.o: $(srcdir)/src/generic/wizard.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_COCOA@advdll_hidjoystick.o: $(srcdir)/src/osx/core/hidjoystick.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_COCOA@ $(CXXC) -c -o $@ $(ADVDLL_CXXFLAGS) $(srcdir)/src/osx/core/hidjoystick.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA@advdll_core_sound.o: $(srcdir)/src/osx/core/sound.cpp $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA@ $(CXXC) -c -o $@ $(ADVDLL_CXXFLAGS) $(srcdir)/src/osx/core/sound.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA@advdll_cocoa_aboutdlg.o: $(srcdir)/src/osx/cocoa/aboutdlg.mm $(ADVDLL_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA@ $(CXXC) -c -o $@ $(ADVDLL_OBJCXXFLAGS) $(srcdir)/src/osx/cocoa/aboutdlg.mm
|
||||
|
||||
@@ -32134,6 +32173,12 @@ advlib_wizard.o: $(srcdir)/src/generic/wizard.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@advlib_carbon_dataview.o: $(srcdir)/src/osx/carbon/dataview.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@ $(CXXC) -c -o $@ $(ADVLIB_CXXFLAGS) $(srcdir)/src/osx/carbon/dataview.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON@advlib_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@ $(CXXC) -c -o $@ $(ADVLIB_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA@advlib_sound_osx.o: $(srcdir)/src/osx/sound_osx.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA@ $(CXXC) -c -o $@ $(ADVLIB_CXXFLAGS) $(srcdir)/src/osx/sound_osx.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_CARBON@advlib_carbon_sound.o: $(srcdir)/src/osx/carbon/sound.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_CARBON@ $(CXXC) -c -o $@ $(ADVLIB_CXXFLAGS) $(srcdir)/src/osx/carbon/sound.cpp
|
||||
|
||||
@@ -32152,6 +32197,9 @@ advlib_wizard.o: $(srcdir)/src/generic/wizard.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_COCOA@advlib_hidjoystick.o: $(srcdir)/src/osx/core/hidjoystick.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_COCOA@ $(CXXC) -c -o $@ $(ADVLIB_CXXFLAGS) $(srcdir)/src/osx/core/hidjoystick.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA@advlib_core_sound.o: $(srcdir)/src/osx/core/sound.cpp $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA@ $(CXXC) -c -o $@ $(ADVLIB_CXXFLAGS) $(srcdir)/src/osx/core/sound.cpp
|
||||
|
||||
@COND_TOOLKIT_OSX_COCOA@advlib_cocoa_aboutdlg.o: $(srcdir)/src/osx/cocoa/aboutdlg.mm $(ADVLIB_ODEP)
|
||||
@COND_TOOLKIT_OSX_COCOA@ $(CXXC) -c -o $@ $(ADVLIB_OBJCXXFLAGS) $(srcdir)/src/osx/cocoa/aboutdlg.mm
|
||||
|
||||
|
@@ -17,6 +17,29 @@
|
||||
|
||||
#include "wx/object.h"
|
||||
|
||||
class WXDLLIMPEXP_ADV wxSoundTimer;
|
||||
|
||||
class WXDLLIMPEXP_ADV wxSoundData
|
||||
{
|
||||
public :
|
||||
wxSoundData();
|
||||
virtual ~wxSoundData();
|
||||
|
||||
virtual bool Play(unsigned int flags) = 0;
|
||||
// stops the sound and deletes the optional timer
|
||||
virtual void Stop();
|
||||
// can be called by a timer for repeated tasks during playback
|
||||
virtual void SoundTask();
|
||||
|
||||
// does the true work of stopping and cleaning up
|
||||
virtual void DoStop() = 0;
|
||||
protected :
|
||||
void CreateAndStartTimer();
|
||||
|
||||
unsigned int m_flags;
|
||||
wxSoundTimer* m_pTimer;
|
||||
} ;
|
||||
|
||||
class WXDLLIMPEXP_ADV wxSound : public wxSoundBase
|
||||
{
|
||||
public:
|
||||
@@ -25,29 +48,31 @@ public:
|
||||
wxSound(int size, const wxByte* data);
|
||||
virtual ~wxSound();
|
||||
|
||||
public:
|
||||
// Create from resource or file
|
||||
bool Create(const wxString& fileName, bool isResource = FALSE);
|
||||
bool IsOk() const { return !m_sndname.IsEmpty(); }
|
||||
// Create from data
|
||||
bool Create(int size, const wxByte* data);
|
||||
|
||||
bool IsOk() const { return m_data != NULL; }
|
||||
|
||||
// Stop playing any sound
|
||||
static void Stop();
|
||||
|
||||
// Returns true if a sound is being played
|
||||
static bool IsPlaying();
|
||||
|
||||
void* GetHandle();
|
||||
// Notification when a sound has stopped
|
||||
static void SoundStopped(const wxSoundData* data);
|
||||
|
||||
protected:
|
||||
bool DoPlay(unsigned flags) const;
|
||||
void Init();
|
||||
|
||||
private:
|
||||
wxString m_sndname; //file path
|
||||
char* m_hSnd; //pointer to resource or memory location
|
||||
int m_waveLength; //size of file in memory mode
|
||||
void* m_pTimer; //timer
|
||||
// data of this object
|
||||
class wxSoundData *m_data;
|
||||
|
||||
enum wxSoundType
|
||||
{
|
||||
wxSound_MEMORY,
|
||||
wxSound_FILE,
|
||||
wxSound_RESOURCE,
|
||||
wxSound_NONE
|
||||
} m_type; //mode
|
||||
wxDECLARE_NO_COPY_CLASS(wxSound);
|
||||
};
|
||||
|
||||
#endif
|
||||
|
@@ -14,6 +14,8 @@
|
||||
|
||||
#if wxUSE_SOUND
|
||||
|
||||
#if wxOSX_USE_QUICKTIME
|
||||
|
||||
#include "wx/sound.h"
|
||||
|
||||
#ifndef WX_PRECOMP
|
||||
@@ -45,63 +47,131 @@
|
||||
//
|
||||
|
||||
#ifdef __WXMAC__
|
||||
#include "wx/osx/uma.h"
|
||||
#ifndef __DARWIN__
|
||||
#include <Movies.h>
|
||||
#include <Gestalt.h>
|
||||
#endif
|
||||
#endif
|
||||
|
||||
#if wxOSX_USE_COCOA
|
||||
#include "wx/osx/private.h"
|
||||
#if wxOSX_USE_COCOA_OR_CARBON
|
||||
#include <QuickTime/QuickTimeComponents.h>
|
||||
#endif
|
||||
|
||||
#include <Carbon/Carbon.h>
|
||||
|
||||
//quicktime media layer only required for mac emulation on pc
|
||||
#ifndef __WXMAC__
|
||||
#else
|
||||
#include <qtml.h>
|
||||
#endif
|
||||
|
||||
#ifndef __DARWIN__
|
||||
#include <QuickTimeComponents.h>
|
||||
#else
|
||||
#include <QuickTime/QuickTimeComponents.h>
|
||||
#endif
|
||||
|
||||
//Time between timer calls
|
||||
#define MOVIE_DELAY 100
|
||||
|
||||
static wxTimer* lastSoundTimer=NULL;
|
||||
static bool lastSoundIsPlaying=false;
|
||||
|
||||
#if !defined(__LP64__)
|
||||
#define USE_QUICKTIME 1
|
||||
#else
|
||||
#define USE_QUICKTIME 0
|
||||
#endif
|
||||
|
||||
#if USE_QUICKTIME
|
||||
// ------------------------------------------------------------------
|
||||
// wxQTTimer - Handle Asyncronous Playing
|
||||
// SoundManager
|
||||
// ------------------------------------------------------------------
|
||||
class wxQTTimer : public wxTimer
|
||||
|
||||
class wxOSXSoundManagerSoundData : public wxSoundData
|
||||
{
|
||||
public:
|
||||
wxQTTimer(Movie movie, bool bLoop, bool* playing) :
|
||||
m_movie(movie), m_bLoop(bLoop), m_pbPlaying(playing)
|
||||
wxOSXSoundManagerSoundData(const wxString& fileName);
|
||||
~wxOSXSoundManagerSoundData();
|
||||
|
||||
virtual bool Play(unsigned flags);
|
||||
virtual void SoundTask();
|
||||
|
||||
void DoStop();
|
||||
protected:
|
||||
SndListHandle m_hSnd;
|
||||
SndChannelPtr m_pSndChannel;
|
||||
};
|
||||
|
||||
wxOSXSoundManagerSoundData::wxOSXSoundManagerSoundData(const wxString& fileName) :
|
||||
m_pSndChannel(NULL)
|
||||
{
|
||||
Str255 lpSnd ;
|
||||
|
||||
wxMacStringToPascal( fileName , lpSnd ) ;
|
||||
|
||||
m_hSnd = (SndListHandle) GetNamedResource('snd ', (const unsigned char *) lpSnd);
|
||||
}
|
||||
|
||||
virtual ~wxQTTimer()
|
||||
wxOSXSoundManagerSoundData::~wxOSXSoundManagerSoundData()
|
||||
{
|
||||
if(m_pbPlaying)
|
||||
*m_pbPlaying = false;
|
||||
DoStop();
|
||||
ReleaseResource((Handle)m_hSnd);
|
||||
}
|
||||
|
||||
StopMovie(m_movie);
|
||||
DisposeMovie(m_movie);
|
||||
void wxOSXSoundManagerSoundData::DoStop()
|
||||
{
|
||||
if ( m_pSndChannel )
|
||||
{
|
||||
SndDisposeChannel(m_pSndChannel, TRUE /* stop immediately, not after playing */);
|
||||
m_pSndChannel = NULL;
|
||||
wxSound::SoundStopped(this);
|
||||
}
|
||||
}
|
||||
|
||||
bool wxOSXSoundManagerSoundData::Play(unsigned flags)
|
||||
{
|
||||
Stop();
|
||||
|
||||
m_flags = flags;
|
||||
|
||||
SoundComponentData data;
|
||||
unsigned long numframes, offset;
|
||||
|
||||
ParseSndHeader((SndListHandle)m_hSnd, &data, &numframes, &offset);
|
||||
|
||||
SndNewChannel(&m_pSndChannel, sampledSynth,
|
||||
initNoInterp
|
||||
+ (data.numChannels == 1 ? initMono : initStereo), NULL);
|
||||
|
||||
if(SndPlay(m_pSndChannel, (SndListHandle) m_hSnd, flags & wxSOUND_ASYNC ? 1 : 0) != noErr)
|
||||
return false;
|
||||
|
||||
if (flags & wxSOUND_ASYNC)
|
||||
CreateAndStartTimer();
|
||||
else
|
||||
DoStop();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
void wxOSXSoundManagerSoundData::SoundTask()
|
||||
{
|
||||
SCStatus stat;
|
||||
|
||||
if (SndChannelStatus((SndChannelPtr)m_pSndChannel, sizeof(SCStatus), &stat) != 0)
|
||||
Stop();
|
||||
|
||||
//if the sound isn't playing anymore, see if it's looped,
|
||||
//and if so play it again, otherwise close things up
|
||||
if (stat.scChannelBusy == FALSE)
|
||||
{
|
||||
if (m_flags & wxSOUND_LOOP)
|
||||
{
|
||||
if(SndPlay((SndChannelPtr)m_pSndChannel, (SndListHandle) m_hSnd, true) != noErr)
|
||||
Stop();
|
||||
}
|
||||
else
|
||||
Stop();
|
||||
}
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// QuickTime
|
||||
// ------------------------------------------------------------------
|
||||
|
||||
bool wxInitQT();
|
||||
bool wxInitQT()
|
||||
{
|
||||
#ifndef __WXMAC__
|
||||
int nError;
|
||||
//-2093 no dll
|
||||
if ((nError = InitializeQTML(0)) != noErr)
|
||||
{
|
||||
wxLogSysError(wxString::Format(wxT("Couldn't Initialize Quicktime-%i"), nError));
|
||||
return false;
|
||||
}
|
||||
#endif
|
||||
EnterMovies();
|
||||
return true;
|
||||
}
|
||||
|
||||
void wxExitQT();
|
||||
void wxExitQT()
|
||||
{
|
||||
//Note that ExitMovies() is not necessary, but
|
||||
//the docs are fuzzy on whether or not TerminateQTML is
|
||||
ExitMovies();
|
||||
@@ -111,209 +181,56 @@ public:
|
||||
#endif
|
||||
}
|
||||
|
||||
void Shutdown()
|
||||
class wxOSXQuickTimeSoundData : public wxSoundData
|
||||
{
|
||||
delete this;
|
||||
}
|
||||
|
||||
void Notify()
|
||||
{
|
||||
if (m_pbPlaying && !*m_pbPlaying)
|
||||
{
|
||||
Shutdown();
|
||||
}
|
||||
|
||||
if(IsMovieDone(m_movie))
|
||||
{
|
||||
if (!m_bLoop)
|
||||
Shutdown();
|
||||
else
|
||||
{
|
||||
StopMovie(m_movie);
|
||||
GoToBeginningOfMovie(m_movie);
|
||||
StartMovie(m_movie);
|
||||
}
|
||||
}
|
||||
else
|
||||
MoviesTask(m_movie, MOVIE_DELAY); //Give QT time to play movie
|
||||
}
|
||||
|
||||
|
||||
Movie& GetMovie() {return m_movie;}
|
||||
public:
|
||||
wxOSXQuickTimeSoundData(const wxString& fileName);
|
||||
wxOSXQuickTimeSoundData(int size, const wxByte* data);
|
||||
~wxOSXQuickTimeSoundData();
|
||||
|
||||
virtual bool Play(unsigned flags);
|
||||
virtual void SoundTask();
|
||||
virtual void DoStop();
|
||||
protected:
|
||||
Movie m_movie;
|
||||
bool m_bLoop;
|
||||
|
||||
public:
|
||||
bool* m_pbPlaying;
|
||||
|
||||
wxString m_sndname; //file path
|
||||
Handle m_soundHandle;
|
||||
};
|
||||
|
||||
|
||||
class wxSMTimer : public wxTimer
|
||||
wxOSXQuickTimeSoundData::wxOSXQuickTimeSoundData(const wxString& fileName) :
|
||||
m_movie(NULL), m_soundHandle(NULL)
|
||||
{
|
||||
public:
|
||||
wxSMTimer(void* hSnd, void* pSndChannel, bool bLoop, bool* playing)
|
||||
: m_hSnd(hSnd), m_pSndChannel(pSndChannel), m_bLoop(bLoop), m_pbPlaying(playing)
|
||||
{
|
||||
}
|
||||
|
||||
virtual ~wxSMTimer()
|
||||
{
|
||||
if(m_pbPlaying)
|
||||
*m_pbPlaying = false;
|
||||
SndDisposeChannel((SndChannelPtr)m_pSndChannel, TRUE);
|
||||
Stop();
|
||||
}
|
||||
|
||||
void Notify()
|
||||
{
|
||||
if (m_pbPlaying && !*m_pbPlaying)
|
||||
{
|
||||
Shutdown();
|
||||
}
|
||||
|
||||
SCStatus stat;
|
||||
|
||||
if (SndChannelStatus((SndChannelPtr)m_pSndChannel, sizeof(SCStatus), &stat) != 0)
|
||||
Shutdown();
|
||||
|
||||
//if the sound isn't playing anymore, see if it's looped,
|
||||
//and if so play it again, otherwise close things up
|
||||
if (stat.scChannelBusy == FALSE)
|
||||
{
|
||||
if (m_bLoop)
|
||||
{
|
||||
if(SndPlay((SndChannelPtr)m_pSndChannel, (SndListHandle) m_hSnd, true) != noErr)
|
||||
Shutdown();
|
||||
}
|
||||
else
|
||||
Shutdown();
|
||||
}
|
||||
}
|
||||
|
||||
void Shutdown()
|
||||
{
|
||||
delete this;
|
||||
}
|
||||
|
||||
void* GetChannel() {return m_pSndChannel;}
|
||||
|
||||
protected:
|
||||
void* m_hSnd;
|
||||
void* m_pSndChannel;
|
||||
bool m_bLoop;
|
||||
|
||||
public:
|
||||
bool* m_pbPlaying;
|
||||
};
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// wxSound
|
||||
// ------------------------------------------------------------------
|
||||
|
||||
//Determines whether version 4 of QT is installed
|
||||
Boolean wxIsQuickTime4Installed (void)
|
||||
{
|
||||
#ifdef __WXMAC__
|
||||
short error;
|
||||
long result;
|
||||
|
||||
error = Gestalt (gestaltQuickTime, &result);
|
||||
return (error == noErr) && (((result >> 16) & 0xffff) >= 0x0400);
|
||||
#else
|
||||
return true;
|
||||
#endif
|
||||
}
|
||||
|
||||
inline bool wxInitQT ()
|
||||
{
|
||||
if (wxIsQuickTime4Installed())
|
||||
{
|
||||
#ifndef __WXMAC__
|
||||
int nError;
|
||||
//-2093 no dll
|
||||
if ((nError = InitializeQTML(0)) != noErr)
|
||||
{
|
||||
wxLogSysError(wxString::Format(wxT("Couldn't Initialize Quicktime-%i"), nError));
|
||||
}
|
||||
#endif
|
||||
EnterMovies();
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
wxLogSysError(wxT("Quicktime is not installed, or Your Version of Quicktime is <= 4."));
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
wxSound::wxSound()
|
||||
: m_hSnd(NULL), m_waveLength(0), m_pTimer(NULL), m_type(wxSound_NONE)
|
||||
{
|
||||
}
|
||||
|
||||
wxSound::wxSound(const wxString& sFileName, bool isResource)
|
||||
: m_hSnd(NULL), m_waveLength(0), m_pTimer(NULL), m_type(wxSound_NONE)
|
||||
{
|
||||
Create(sFileName, isResource);
|
||||
}
|
||||
|
||||
wxSound::wxSound(int size, const wxByte* data)
|
||||
: m_hSnd((char*)data), m_waveLength(size), m_pTimer(NULL), m_type(wxSound_MEMORY)
|
||||
{
|
||||
}
|
||||
|
||||
wxSound::~wxSound()
|
||||
{
|
||||
}
|
||||
|
||||
bool wxSound::Create(const wxString& fileName, bool isResource)
|
||||
{
|
||||
Stop();
|
||||
|
||||
if (isResource)
|
||||
{
|
||||
#ifdef __WXMAC__
|
||||
m_type = wxSound_RESOURCE;
|
||||
|
||||
Str255 lpSnd ;
|
||||
|
||||
wxMacStringToPascal( fileName , lpSnd ) ;
|
||||
|
||||
m_sndname = fileName;
|
||||
m_hSnd = (char*) GetNamedResource('snd ', (const unsigned char *) lpSnd);
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
else
|
||||
{
|
||||
m_type = wxSound_FILE;
|
||||
m_sndname = fileName;
|
||||
}
|
||||
|
||||
return true;
|
||||
wxOSXQuickTimeSoundData::wxOSXQuickTimeSoundData(int size, const wxByte* data) :
|
||||
m_movie(NULL)
|
||||
{
|
||||
m_soundHandle = NewHandleClear((Size)size);
|
||||
BlockMove(data, *m_soundHandle, size);
|
||||
}
|
||||
|
||||
bool wxSound::DoPlay(unsigned flags) const
|
||||
wxOSXQuickTimeSoundData::~wxOSXQuickTimeSoundData()
|
||||
{
|
||||
if ( m_soundHandle )
|
||||
DisposeHandle(m_soundHandle);
|
||||
}
|
||||
|
||||
bool wxOSXQuickTimeSoundData::Play(unsigned flags)
|
||||
{
|
||||
if ( m_movie )
|
||||
Stop();
|
||||
|
||||
#if USE_QUICKTIME
|
||||
m_flags = flags;
|
||||
|
||||
Movie movie;
|
||||
|
||||
switch(m_type)
|
||||
{
|
||||
case wxSound_MEMORY:
|
||||
{
|
||||
if (!wxInitQT())
|
||||
return false;
|
||||
Handle myHandle, dataRef = nil;
|
||||
|
||||
if( m_soundHandle )
|
||||
{
|
||||
Handle dataRef = nil;
|
||||
MovieImportComponent miComponent;
|
||||
Track targetTrack = nil;
|
||||
TimeValue addedDuration = 0;
|
||||
@@ -321,28 +238,27 @@ bool wxSound::DoPlay(unsigned flags) const
|
||||
OSErr err;
|
||||
ComponentResult result;
|
||||
|
||||
myHandle = NewHandleClear((Size)m_waveLength);
|
||||
err = PtrToHand(&m_soundHandle, &dataRef, sizeof(Handle));
|
||||
|
||||
BlockMove(m_hSnd, *myHandle, m_waveLength);
|
||||
|
||||
err = PtrToHand(&myHandle, &dataRef, sizeof(Handle));
|
||||
|
||||
if (memcmp(&m_hSnd[8], "WAVE", 4) == 0)
|
||||
HLock(m_soundHandle);
|
||||
if (memcmp(&(*m_soundHandle)[8], "WAVE", 4) == 0)
|
||||
miComponent = OpenDefaultComponent(MovieImportType, kQTFileTypeWave);
|
||||
else if (memcmp(&m_hSnd[8], "AIFF", 4) == 0)
|
||||
else if (memcmp(&(*m_soundHandle)[8], "AIFF", 4) == 0)
|
||||
miComponent = OpenDefaultComponent(MovieImportType, kQTFileTypeAIFF);
|
||||
else if (memcmp(&m_hSnd[8], "AIFC", 4) == 0)
|
||||
else if (memcmp(&(*m_soundHandle)[8], "AIFC", 4) == 0)
|
||||
miComponent = OpenDefaultComponent(MovieImportType, kQTFileTypeAIFC);
|
||||
else
|
||||
{
|
||||
HUnlock(m_soundHandle);
|
||||
wxLogSysError(wxT("wxSound - Location in memory does not contain valid data"));
|
||||
return false;
|
||||
}
|
||||
|
||||
movie = NewMovie(0);
|
||||
HUnlock(m_soundHandle);
|
||||
m_movie = NewMovie(0);
|
||||
|
||||
result = MovieImportDataRef(miComponent, dataRef,
|
||||
HandleDataHandlerSubType, movie,
|
||||
HandleDataHandlerSubType, m_movie,
|
||||
nil, &targetTrack,
|
||||
nil, &addedDuration,
|
||||
movieImportCreateTrack, &outFlags);
|
||||
@@ -352,48 +268,11 @@ bool wxSound::DoPlay(unsigned flags) const
|
||||
wxLogSysError(wxString::Format(wxT("Couldn't import movie data\nError:%i"), (int)result));
|
||||
}
|
||||
|
||||
SetMovieVolume(movie, kFullVolume);
|
||||
GoToBeginningOfMovie(movie);
|
||||
|
||||
DisposeHandle(myHandle);
|
||||
}
|
||||
break;
|
||||
case wxSound_RESOURCE:
|
||||
{
|
||||
SoundComponentData data;
|
||||
unsigned long numframes, offset;
|
||||
|
||||
ParseSndHeader((SndListHandle)m_hSnd, &data, &numframes, &offset);
|
||||
//m_waveLength = numFrames * data.numChannels;
|
||||
|
||||
SndChannelPtr pSndChannel;
|
||||
SndNewChannel(&pSndChannel, sampledSynth,
|
||||
initNoInterp
|
||||
+ (data.numChannels == 1 ? initMono : initStereo), NULL);
|
||||
|
||||
if(SndPlay(pSndChannel, (SndListHandle) m_hSnd, flags & wxSOUND_ASYNC ? 1 : 0) != noErr)
|
||||
return false;
|
||||
|
||||
if (flags & wxSOUND_ASYNC)
|
||||
{
|
||||
lastSoundTimer = ((wxSMTimer*&)m_pTimer)
|
||||
= new wxSMTimer(pSndChannel, m_hSnd, flags & wxSOUND_LOOP ? 1 : 0,
|
||||
&lastSoundIsPlaying);
|
||||
lastSoundIsPlaying = true;
|
||||
|
||||
((wxTimer*)m_pTimer)->Start(MOVIE_DELAY, wxTIMER_CONTINUOUS);
|
||||
SetMovieVolume(m_movie, kFullVolume);
|
||||
GoToBeginningOfMovie(m_movie);
|
||||
}
|
||||
else
|
||||
SndDisposeChannel(pSndChannel, TRUE);
|
||||
|
||||
return true;
|
||||
}
|
||||
break;
|
||||
case wxSound_FILE:
|
||||
{
|
||||
if (!wxInitQT())
|
||||
return false;
|
||||
|
||||
OSErr err = noErr ;
|
||||
|
||||
Handle dataRef = NULL;
|
||||
@@ -406,7 +285,7 @@ bool wxSound::DoPlay(unsigned flags) const
|
||||
|
||||
if (NULL != dataRef || err != noErr)
|
||||
{
|
||||
err = NewMovieFromDataRef( &movie, newMovieDontAskUnresolvedDataRefs , NULL, dataRef, dataRefType );
|
||||
err = NewMovieFromDataRef( &m_movie, newMovieDontAskUnresolvedDataRefs , NULL, dataRef, dataRefType );
|
||||
wxASSERT(err == noErr);
|
||||
DisposeHandle(dataRef);
|
||||
}
|
||||
@@ -419,22 +298,13 @@ bool wxSound::DoPlay(unsigned flags) const
|
||||
return false;
|
||||
}
|
||||
}
|
||||
break;
|
||||
default:
|
||||
return false;
|
||||
}//end switch(m_type)
|
||||
|
||||
//Start the movie!
|
||||
StartMovie(movie);
|
||||
//Start the m_movie!
|
||||
StartMovie(m_movie);
|
||||
|
||||
if (flags & wxSOUND_ASYNC)
|
||||
{
|
||||
//Start timer and play movie asyncronously
|
||||
lastSoundTimer = ((wxQTTimer*&)m_pTimer) =
|
||||
new wxQTTimer(movie, flags & wxSOUND_LOOP ? 1 : 0,
|
||||
&lastSoundIsPlaying);
|
||||
lastSoundIsPlaying = true;
|
||||
((wxQTTimer*)m_pTimer)->Start(MOVIE_DELAY, wxTIMER_CONTINUOUS);
|
||||
CreateAndStartTimer();
|
||||
}
|
||||
else
|
||||
{
|
||||
@@ -443,40 +313,59 @@ bool wxSound::DoPlay(unsigned flags) const
|
||||
//Play movie until it ends, then exit
|
||||
//Note that due to quicktime caching this may not always
|
||||
//work 100% correctly
|
||||
while (!IsMovieDone(movie))
|
||||
MoviesTask(movie, 1);
|
||||
while (!IsMovieDone(m_movie))
|
||||
MoviesTask(m_movie, 1);
|
||||
|
||||
DisposeMovie(movie);
|
||||
DoStop();
|
||||
}
|
||||
#endif
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool wxSound::IsPlaying()
|
||||
void wxOSXQuickTimeSoundData::DoStop()
|
||||
{
|
||||
return lastSoundIsPlaying;
|
||||
}
|
||||
|
||||
void wxSound::Stop()
|
||||
if( m_movie )
|
||||
{
|
||||
if (lastSoundIsPlaying)
|
||||
{
|
||||
delete (wxTimer*&) lastSoundTimer;
|
||||
lastSoundIsPlaying = false;
|
||||
lastSoundTimer = NULL;
|
||||
StopMovie(m_movie);
|
||||
DisposeMovie(m_movie);
|
||||
m_movie = NULL;
|
||||
wxSound::SoundStopped(this);
|
||||
wxExitQT();
|
||||
}
|
||||
}
|
||||
|
||||
void* wxSound::GetHandle()
|
||||
void wxOSXQuickTimeSoundData::SoundTask()
|
||||
{
|
||||
#if USE_QUICKTIME
|
||||
if(m_type == wxSound_RESOURCE)
|
||||
return (void*) ((wxSMTimer*)m_pTimer)->GetChannel();
|
||||
|
||||
return (void*) ((wxQTTimer*) m_pTimer)->GetMovie();
|
||||
#endif
|
||||
return NULL;
|
||||
if(IsMovieDone(m_movie))
|
||||
{
|
||||
if (m_flags & wxSOUND_LOOP)
|
||||
{
|
||||
StopMovie(m_movie);
|
||||
GoToBeginningOfMovie(m_movie);
|
||||
StartMovie(m_movie);
|
||||
}
|
||||
else
|
||||
Stop();
|
||||
}
|
||||
else
|
||||
MoviesTask(m_movie, MOVIE_DELAY); //Give QT time to play movie
|
||||
}
|
||||
|
||||
bool wxSound::Create(int size, const wxByte* data)
|
||||
{
|
||||
m_data = new wxOSXQuickTimeSoundData(size,data);
|
||||
return true;
|
||||
}
|
||||
|
||||
bool wxSound::Create(const wxString& fileName, bool isResource)
|
||||
{
|
||||
if ( isResource )
|
||||
m_data = new wxOSXSoundManagerSoundData(fileName);
|
||||
else
|
||||
m_data = new wxOSXQuickTimeSoundData(fileName);
|
||||
return true;
|
||||
}
|
||||
|
||||
#endif // wxOSX_USE_QUICKTIME
|
||||
|
||||
#endif //wxUSE_SOUND
|
||||
|
Reference in New Issue
Block a user