git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@25472
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
# endif
#endif /* !defined(wxUSE_SLIDER) */
# endif
#endif /* !defined(wxUSE_SLIDER) */
+#ifndef wxUSE_SOUND
+# ifdef wxABORT_ON_CONFIG_ERROR
+# error "wxUSE_SOUND must be defined."
+# else
+# define wxUSE_SOUND 0
+# endif
+#endif /* !defined(wxUSE_SOUND) */
+
#ifndef wxUSE_SPINBTN
# ifdef wxABORT_ON_CONFIG_ERROR
# error "wxUSE_SPINBTN must be defined."
#ifndef wxUSE_SPINBTN
# ifdef wxABORT_ON_CONFIG_ERROR
# error "wxUSE_SPINBTN must be defined."
#pragma interface "soundbase.h"
#endif
#pragma interface "soundbase.h"
#endif
+#include "wx/defs.h"
+
+#if wxUSE_SOUND
+
#include "wx/object.h"
// ----------------------------------------------------------------------------
#include "wx/object.h"
// ----------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// Flags for wxSound::Play
// ----------------------------------------------------------------------------
// Flags for wxSound::Play
-enum wxSoundFlags
-{
- wxSOUND_SYNC = 0,
- wxSOUND_ASYNC = 1,
- wxSOUND_LOOP = 2
-};
+#if WXWIN_COMPATIBILITY_2_4
+ // NB: we can't use enum because there would be ambiguity between the
+ // two Play() prototypes when called without explicit parameters
+ #define wxSOUND_SYNC ((unsigned)0)
+ #define wxSOUND_ASYNC ((unsigned)1)
+ #define wxSOUND_LOOP ((unsigned)2)
+#else
+ enum wxSoundFlags
+ {
+ wxSOUND_SYNC = 0,
+ wxSOUND_ASYNC = 1,
+ wxSOUND_LOOP = 2
+ };
+#endif
+// Base class for wxSound implementations
class wxSoundBase : public wxObject
{
public:
// Play the sound:
class wxSoundBase : public wxObject
{
public:
// Play the sound:
- bool Play(unsigned flags = wxSOUND_ASYNC)
+ bool Play(unsigned flags = wxSOUND_ASYNC) const
+ wxASSERT_MSG( (flags & wxSOUND_LOOP) == 0 ||
+ (flags & wxSOUND_ASYNC) != 0,
+ _T("sound can only be looped asynchronously") );
return DoPlay(flags);
}
#if WXWIN_COMPATIBILITY_2_4
return DoPlay(flags);
}
#if WXWIN_COMPATIBILITY_2_4
- wxDEPRECATED( bool Play(bool async = true, bool looped = false) );
+ wxDEPRECATED( bool Play(bool async, bool looped = false) const );
+ // Plays sound from filename:
+ static bool Play(const wxString& filename, unsigned flags = wxSOUND_ASYNC);
+
- virtual bool DoPlay(unsigned flags) = 0;
+ virtual bool DoPlay(unsigned flags) const = 0;
-
-#if WXWIN_COMPATIBILITY_2_4
-inline bool wxSoundBase::Play(bool async, bool looped)
-{
- unsigned flags = 0;
- if (async) flags |= wxSOUND_ASYNC;
- if (looped) flags |= wxSOUND_LOOP | wxSOUND_ASYNC;
- return DoPlay(flags);
-}
-#endif
// ----------------------------------------------------------------------------
// wxSound class implementation
// ----------------------------------------------------------------------------
#if defined(__WXMSW__)
// ----------------------------------------------------------------------------
// wxSound class implementation
// ----------------------------------------------------------------------------
#if defined(__WXMSW__)
-#include "wx/msw/wave.h"
+ #include "wx/msw/sound.h"
-#include "wx/unix/sound.h"
+ #include "wx/unix/sound.h"
-#include "wx/mac/wave.h"
+ #include "wx/mac/sound.h"
-#include "wx/os2/wave.h"
+ #include "wx/os2/sound.h"
-// wxSound used to be called wxWave before wxWindows 2.5.1:
-#ifdef __UNIX__ // FIXME: on all platforms when everything is renamed
- #if WXWIN_COMPATIBILITY_2_4
- typedef wxSound wxWave;
- #endif
-#else
- typedef wxWave wxSound;
+// ----------------------------------------------------------------------------
+// wxSoundBase methods
+// ----------------------------------------------------------------------------
+
+inline bool wxSoundBase::Play(const wxString& filename, unsigned flags)
+{
+ wxSound snd(filename);
+ return snd.IsOk() ? snd.Play(flags) : false;
+}
+
+#if WXWIN_COMPATIBILITY_2_4
+inline bool wxSoundBase::Play(bool async, bool looped) const
+{
+ unsigned flags = 0;
+ if (async) flags |= wxSOUND_ASYNC;
+ if (looped) flags |= wxSOUND_LOOP | wxSOUND_ASYNC;
+ return DoPlay(flags);
+}
#endif // _WX_SOUND_H_BASE_
#endif // _WX_SOUND_H_BASE_
/////////////////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////////////////
// Purpose: wxSound class
// Author: Julian Smart, Vaclav Slavik
// Modified by:
// Purpose: wxSound class
// Author: Julian Smart, Vaclav Slavik
// Modified by:
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma interface "sound.h"
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma interface "sound.h"
static void UnloadBackend();
protected:
static void UnloadBackend();
protected:
- bool DoPlay(unsigned flags);
+ bool DoPlay(unsigned flags) const;
static void EnsureBackend();
void Free();
static void EnsureBackend();
void Free();
#if WXWIN_COMPATIBILITY_2_4
#warning "wx/wave.h header is deprecated, use wx/sound.h and wxSound"
#include "wx/sound.h"
#if WXWIN_COMPATIBILITY_2_4
#warning "wx/wave.h header is deprecated, use wx/sound.h and wxSound"
#include "wx/sound.h"
+ // wxSound used to be called wxWave before wxWindows 2.5.1:
+ typedef wxSound wxWave;
#else
#error "wx/wave.h is only available in compatibility mode"
#endif
#endif
#else
#error "wx/wave.h is only available in compatibility mode"
#endif
#endif