X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7ac36741b106a8936ede1c61bf19171f7a8a2a3d..4c1e8a6952d9a68f0ca07d1ef4a0ad42d89d16ee:/wxPython/demo/Sound.py

diff --git a/wxPython/demo/Sound.py b/wxPython/demo/Sound.py
index 871fdde068..2584de414c 100644
--- a/wxPython/demo/Sound.py
+++ b/wxPython/demo/Sound.py
@@ -22,9 +22,9 @@ class TestPanel(wx.Panel):
 
     def OnButton1(self, evt):
         try:
-            self.sound = wx.Sound(opj('data/anykey.wav'))
+            sound = wx.Sound(opj('data/anykey.wav'))
             self.log.write("before Play...\n")
-            self.sound.Play(wx.SOUND_SYNC)
+            sound.Play(wx.SOUND_SYNC)
             self.log.write("...after Play\n")
         except NotImplementedError, v:
             wx.MessageBox(str(v), "Exception Message")
@@ -33,14 +33,15 @@ class TestPanel(wx.Panel):
     def OnButton2(self, evt):
         try:
             if True:
-                self.sound = wx.Sound(opj('data/plan.wav'))
+                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()
-                self.sound = wx.SoundFromData(data)
+                sound = wx.SoundFromData(data)
                 
             self.log.write("before Play...\n")
-            self.sound.Play(wx.SOUND_ASYNC)
+            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:
@@ -54,9 +55,12 @@ class TestPanel(wx.Panel):
                             style=wx.OPEN)
         if dlg.ShowModal() == wx.ID_OK:
             try:
-                #self.sound = wx.Sound(dlg.GetPath())
-                #self.sound.Play()
-                wx.Sound.PlaySound(dlg.GetPath())
+                #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()