X-Git-Url: https://svn.cri.ensmp.fr/git/minwii.git/blobdiff_plain/f7094076a9f447c33341612d1a530141d35d1a3a..62d5191553d75c84d63ace49f6f5173a35773c88:/src/app/eventutils.py diff --git a/src/app/eventutils.py b/src/app/eventutils.py index 969ad81..3ce142d 100755 --- a/src/app/eventutils.py +++ b/src/app/eventutils.py @@ -6,7 +6,7 @@ l'implémentation des gestionnaires d'événements pygame. Utilisation : - hériter de EventHandlerMixin - décorer les méthodes gestionnaires d'événements avec le décorateur 'event_handler' - en passant en paramètre le code d'événement pygame + en passant en paramètre un ou plusieurs codes d'événement pygame Il n'existe aucune contrainte sur le nommage de la méthode décorée. La méthode gestionnaire d'événement reçoit l'événement pygame comme unique paramètre. @@ -31,8 +31,16 @@ import pygame from StringIO import StringIO from logging import getLogger, basicConfig, DEBUG import sys +from events import TIMEOUT, COLOVER, eventNames basicConfig(level=DEBUG, stream = sys.stdout) -console = getLogger('minwii.eventutils') +console = getLogger('minwii') +eventLog = getLogger('minwii.events') + +hiddenEvents = {pygame.MOUSEMOTION:True, + TIMEOUT:True, + #COLOVER:True, + } +from event_pprinters import pprinters class _EventDispatcher : def __init__(self) : @@ -53,14 +61,12 @@ class _EventDispatcher : def dispatchEvents(self) : events = pygame.event.get() for event in events : - #if event.type == pygame.MOUSEMOTION : - # if hasattr(event, 'wiimoteid') : - # console.info(event) - # #return - listeners = self.registry.get(event.type, {}) + if listeners and not hiddenEvents.has_key(event.type) : + eventLog.info(pprinters[event.type](event)) for listener in listeners.keys() : listener(event) + def reset(self) : self.registry = {} @@ -109,8 +115,3 @@ class EventInitializer(type): class EventHandlerMixin(object) : __metaclass__ = EventInitializer - - #def input(self) : - # event = pygame.event.wait() - # handler = getattr(self, 'eventHandler%s' % event.type, lambda e:None) - # handler(event)