]> CRI, Mines Paris - PSL - minwii.git/commitdiff
Clignotement du curseur basé sur un thread indépendant de pygame.
authorpin <pin@fe552daf-6dbe-4428-90eb-1537e0879342>
Mon, 17 May 2010 14:09:33 +0000 (14:09 +0000)
committerpin <pin@fe552daf-6dbe-4428-90eb-1537e0879342>
Mon, 17 May 2010 14:09:33 +0000 (14:09 +0000)
Bugfix.

git-svn-id: https://svn.cri.ensmp.fr/svn/minwii/trunk@166 fe552daf-6dbe-4428-90eb-1537e0879342

src/app/events.py
src/app/log.py
src/app/logfilereader.py
src/app/widgets/cursors.py
src/app/widgets/playingscreen.py

index 6b90d92a2670f1e92eb0b671000104ec6513dfaa..a67a416cbe8816b69d1b2cbe8eae678567bb7801 100755 (executable)
@@ -1,8 +1,7 @@
 import pygame
 from sys import modules
 
-events = ['TIMEOUT',
-          'NOTEON',
+events = ['NOTEON',
           'NOTEOFF',
           'NOTEEND',
           'COLDOWN',
@@ -14,7 +13,7 @@ eventNames = {}
 self = modules[__name__]
 
 for i, name in enumerate(events) :
-    eventType = pygame.USEREVENT+i
+    eventType = pygame.USEREVENT + 1 + i
     eventNames[eventType] = name
     setattr(self, name, eventType)
 
index 3cffbb3b14ba8286e29a27a55a0a279b467a783e..abbb8587fdc898959e064264255729071bad3766 100755 (executable)
@@ -6,7 +6,7 @@ $Id$
 $URL$
 """
 
-from events import TIMEOUT, COLOVER, eventNames
+from events import COLOVER, eventNames
 from event_pprinters import pprinters
 import sys
 import pygame
@@ -18,7 +18,6 @@ LOG_FORMAT_VERSION='1.0'
 hiddenEvents = {pygame.MOUSEMOTION:True,
                 pygame.MOUSEBUTTONDOWN:True,
                 pygame.MOUSEBUTTONUP:True,
-                TIMEOUT:True,
                 #COLOVER:True,
                 }
 
index f5f5d5429d9e995db9c1ebeeac3030a62a7387af..64711c10d6670f7b65de76fdc58725427579928e 100755 (executable)
@@ -209,4 +209,6 @@ class LogFilePlayer(PlayingScreenBase) :
             
             previousTicks = ticks
         
+        self.stop()
+        
     
\ No newline at end of file
index 1e3fc4ed3294827db262d9d0e2832e392007bdde..c8df10412812bcc4062fb28fec5f92dbbf508d17 100755 (executable)
@@ -8,8 +8,9 @@ $URL$
 
 import pygame
 import os
+from threading import Thread
+import time
 from eventutils import EventHandlerMixin, event_handler
-from events import TIMEOUT
 from itertools import cycle
 
 class WarpingCursor(pygame.sprite.DirtySprite, EventHandlerMixin):
@@ -60,22 +61,27 @@ class WarpingCursor(pygame.sprite.DirtySprite, EventHandlerMixin):
         self.blinkMode = blinkMode
         self._startBlink()
     
+    def __del__(self) :
+        if hasattr(self, 'timer') :
+            try : self.timer.stop()
+            except : pass
+    
     def _startBlink(self) :
         if self.blinkMode :
             self._blinking = True
-            pygame.time.set_timer(TIMEOUT, self.duration)
             self.iterator = self.iterImages()
+            self.timer = ForeverTimer(self.duration, self.loadNext)
+            self.timer.start()
     
     def _stopBlink(self) :
         if self.blinkMode :
-            pygame.time.set_timer(TIMEOUT, 0)
+            self.timer.stop()
             
     def iterImages(self) :
         for img in cycle(self.images) :
             yield img
     
-    @event_handler(TIMEOUT)
-    def loadNext(self, event) :
+    def loadNext(self) :
         if self._blinking :
             self.dirty = 1
             self.image = self.iterator.next()
@@ -91,7 +97,6 @@ class WarpingCursor(pygame.sprite.DirtySprite, EventHandlerMixin):
         self.dirty = 1
         if self.blinkMode :
             self._blinking = True
-            self.loadNext(event)
         else :
             self.image = self.images[0]
     
@@ -105,3 +110,21 @@ class WarpingCursor(pygame.sprite.DirtySprite, EventHandlerMixin):
         x, y = pos
         rx, ry = self.rect.centerx, self.rect.centery
         self.rect.move_ip(x-rx, y-ry)
+
+
+class ForeverTimer(Thread) :
+    def __init__(self, duration, func, *args, **kw) :
+        Thread.__init__(self)
+        self.duration = duration / 1000.
+        self.func = func
+        self.args = args
+        self.kw = kw
+        self.running = True
+
+    def run(self) :
+        while self.running :
+            self.func(*self.args, **self.kw)
+            time.sleep(self.duration)
+    
+    def stop(self) :
+        self.running = False
\ No newline at end of file
index 67039e7492b3872ed47994a6a3fe6cd83ccf9a82..75f68fd1c8fb1831fe78873c7e41b4f0847f3a2e 100755 (executable)
@@ -88,7 +88,7 @@ class PlayingScreenBase(pygame.sprite.LayeredDirty, EventHandlerMixin) :
             EventDispatcher.dispatchEvents()
             dirty = self.draw(pygame.display.get_surface())
             pygame.display.update(dirty)
-            clock.tick()
+            clock.tick(FRAMERATE)
     
     def stop(self) :
         self._running = False