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
:
52 keys
= self
.registry
.keys()
55 print >> out
, "event", k
56 for listener
in self
.registry
[k
] :
57 print >> out
, listener
.__name
__
62 EventDispatcher
= _EventDispatcher()
64 def event_handler(eventType
) :
65 def markFunctionAsListener(m
) :
66 m
.__islistener
__ = True
67 m
.__eventtype
__ = eventType
69 return markFunctionAsListener
72 class EventInitializer(type):
74 def __init__(cls
, name
, bases
, dict) :
75 def init_listeners(self
) :
76 for k
, v
in dict.items() :
77 if isinstance(v
, types
.FunctionType
) and hasattr(v
, '__islistener__') :
78 listener
= getattr(self
, k
)
79 EventDispatcher
.addEventListener(v
.__eventtype
__, listener
)
81 def ctor(self
, *args
, **kw
) :
82 default_ctor
= dict.get('__init__')
84 super(cls
, self
).__init
__(*args
, **kw
)
86 default_ctor(self
, *args
, **kw
)
92 class EventHandlerMixin(object) :
93 __metaclass__
= EventInitializer
96 # event = pygame.event.wait()
97 # handler = getattr(self, 'eventHandler%s' % event.type, lambda e:None)