1 # -*- coding: utf-8 -*-
3 Décorateur, métaclasse et classe mixin pour faciliter
4 l'implémentation des gestionnaires d'événements pygame.
7 - hériter de EventHandlerMixin
8 - décorer les méthodes gestionnaires d'événements avec le décorateur 'event_handler'
9 en passant en paramètre le code d'événement pygame
11 Il n'existe aucune contrainte sur le nommage de la méthode décorée.
12 La méthode gestionnaire d'événement reçoit l'événement pygame comme unique paramètre.
17 class Machin(pygame.sprite.Sprite, EventHandlerMixin) :
21 @event_handler(pygame.KEYDOWN)
22 def handleKeyDown(self, event) :
31 from StringIO
import StringIO
33 class _EventDispatcher
:
37 def addEventListener(self
, eventType
, listener
) :
38 if self
.registry
.has_key(eventType
) :
39 self
.registry
[eventType
].append(listener
)
41 self
.registry
[eventType
] = [listener
]
43 def dispatchEvents(self
) :
44 events
= pygame
.event
.get()
46 listeners
= self
.registry
.get(event
.type, [])
47 for listener
in listeners
:
54 keys
= self
.registry
.keys()
57 print >> out
, "event", k
58 for listener
in self
.registry
[k
] :
59 print >> out
, listener
.__name
__
64 EventDispatcher
= _EventDispatcher()
66 def event_handler(eventType
) :
67 def markFunctionAsListener(m
) :
68 m
.__islistener
__ = True
69 m
.__eventtype
__ = eventType
71 return markFunctionAsListener
74 class EventInitializer(type):
76 def __init__(cls
, name
, bases
, dict) :
77 def init_listeners(self
) :
78 for k
, v
in dict.items() :
79 if isinstance(v
, types
.FunctionType
) and hasattr(v
, '__islistener__') :
80 listener
= getattr(self
, k
)
81 EventDispatcher
.addEventListener(v
.__eventtype
__, listener
)
83 def ctor(self
, *args
, **kw
) :
84 default_ctor
= dict.get('__init__')
86 super(cls
, self
).__init
__(*args
, **kw
)
88 default_ctor(self
, *args
, **kw
)
94 class EventHandlerMixin(object) :
95 __metaclass__
= EventInitializer
98 # event = pygame.event.wait()
99 # handler = getattr(self, 'eventHandler%s' % event.type, lambda e:None)