X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b2bacf13e35b54b68ba707894630eff0e36da6b1..6ecc8943e9f284fde75e16edfaed95064b5f89c4:/wxPython/demo/Sound.py diff --git a/wxPython/demo/Sound.py b/wxPython/demo/Sound.py index 456733b5bf..2584de414c 100644 --- a/wxPython/demo/Sound.py +++ b/wxPython/demo/Sound.py @@ -9,7 +9,7 @@ class TestPanel(wx.Panel): def __init__(self, parent, log): wx.Panel.__init__(self, parent, -1) self.log = log - + b = wx.Button(self, -1, "Play Sound 1 (sync)", (25, 25)) self.Bind(wx.EVT_BUTTON, self.OnButton1, b) @@ -32,9 +32,16 @@ class TestPanel(wx.Panel): def OnButton2(self, evt): try: - sound = wx.Sound(opj('data/plan.wav')) + if True: + sound = wx.Sound(opj('data/plan.wav')) + else: + # sounds can also be loaded from a buffer object + data = open(opj('data/plan.wav'), 'rb').read() + sound = wx.SoundFromData(data) + self.log.write("before Play...\n") sound.Play(wx.SOUND_ASYNC) + self.sound = sound # save a reference (This shoudln't be needed, but there seems to be a bug...) wx.YieldIfNeeded() self.log.write("...after Play\n") except NotImplementedError, v: @@ -48,12 +55,16 @@ class TestPanel(wx.Panel): style=wx.OPEN) if dlg.ShowModal() == wx.ID_OK: try: - sound = wx.Sound(dlg.GetPath()) - sound.Play() + #sound = wx.Sound(dlg.GetPath(), wx.SOUND_SYNC) + #sound.Play() + + # another way to do it. + wx.Sound.PlaySound(dlg.GetPath(), wx.SOUND_SYNC) + except NotImplementedError, v: wx.MessageBox(str(v), "Exception Message") dlg.Destroy() - + #---------------------------------------------------------------------- @@ -66,8 +77,8 @@ def runTest(frame, nb, log): overview = """
This demo offers two examples, both driven by buttons, but obviously the event