Mercurial > parpg-source
view common/listeners/event_listener.py @ 2:06145a6ee387
Fixed resource path dependencies issue that caused PARPG to crash on start.
* PARPG should now run without issue (system installation not tested).
* Utilized FIFE's VFS module to remove path dependencies from most PARPG modules.
* The new parpg.vfs module is a singleton with a single global variable, VFS, which is a reference to the global VFS instance. Although a singleton is not ideal it should be replaced once PARPG's core code is refactored.
* The parpg.vfs singleton is initialized in the parpg.applicaiton.PARPGApplication class with the absolute path to the data directory via the parpg.settings module and corresponding configuration file.
* A new DataPath entry was added to the default system configuration file template under the [parpg] section to support the new parpg.vfs module.
* Updated the parpg-assets subrepo to revision 3 to fix some dialog file format issues (for details see commit message for parpg-assets).
* Fixed a few bugs in the parpg.dialogueparsers.YAMLDialogueParser class related to exception handling.
author | M. George Hansen <technopolitica@gmail.com> |
---|---|
date | Mon, 06 Jun 2011 15:56:14 -1000 |
parents | 7a89ea5404b1 |
children | 80672955ab70 |
line wrap: on
line source
#!/usr/bin/env python # This file is part of PARPG. # PARPG is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # PARPG is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # You should have received a copy of the GNU General Public License # along with PARPG. If not, see <http://www.gnu.org/licenses/>. """This module contains the EventListener that receives events and distributes them to PARPG listeners""" from fife import fife import logging logger = logging.getLogger('event_listener') class EventListener(fife.IKeyListener, fife.ICommandListener, fife.IMouseListener, fife.ConsoleExecuter): """Class that receives all events and distributes them to the listeners""" def __init__(self, engine): """Initialize the instance""" self.event_manager = engine.getEventManager() fife.IKeyListener.__init__(self) self.event_manager.addKeyListener(self) fife.ICommandListener.__init__(self) self.event_manager.addCommandListener(self) fife.IMouseListener.__init__(self) self.event_manager.addMouseListener(self) fife.ConsoleExecuter.__init__(self) engine.getGuiManager().getConsole().setConsoleExecuter(self) self.listeners = {"Mouse" : [], "Key" : [], "Command" : [], "ConsoleCommand" : [], "Widget" : []} def addListener(self, listener_type, listener): """Adds a listener""" if listener_type in self.listeners.iterkeys(): if not listener in self.listeners[listener_type]: self.listeners[listener_type].append(listener) else: logger.warning("Listener type " "'{0}' not supported".format(listener_type)) def removeListener(self, listener_type, listener): """Removes a listener""" if listener_type in self.listeners.iterkeys(): self.listeners[listener_type].remove(listener) else: logger.warning("Listener type " "'{0}' not supported".format(listener_type)) def mousePressed(self, evt): """Called when a mouse button is pressed""" for listeners in self.listeners["Mouse"]: listeners.mousePressed(evt) def mouseReleased(self, evt): """Called when a mouse button is released""" for listeners in self.listeners["Mouse"]: listeners.mouseReleased(evt) def mouseEntered(self, evt): """Called when a mouse enters a region""" for listeners in self.listeners["Mouse"]: listeners.mouseEntered(evt) def mouseExited(self, evt): """Called when a mouse exits a region""" for listeners in self.listeners["Mouse"]: listeners.mouseExited(evt) def mouseClicked(self, evt): """Called after a mouse button is pressed and released""" for listeners in self.listeners["Mouse"]: listeners.mouseClicked(evt) def mouseWheelMovedUp(self, evt): """Called when the mouse wheel has been moved up""" for listeners in self.listeners["Mouse"]: listeners.mouseWheelMovedUp(evt) def mouseWheelMovedDown(self, evt): """Called when the mouse wheel has been moved down""" for listener in self.listeners["Mouse"]: listener.mouseWheelMovedDown(evt) def mouseMoved(self, evt): """Called when when the mouse has been moved""" for listener in self.listeners["Mouse"]: listener.mouseMoved(evt) def mouseDragged(self, evt): """Called when dragging the mouse""" for listener in self.listeners["Mouse"]: listener.mouseDragged(evt) def keyPressed(self, evt): """Called when a key is being pressed""" for listener in self.listeners["Key"]: listener.keyPressed(evt) def keyReleased(self, evt): """Called when a key is being released""" for listener in self.listeners["Key"]: listener.keyReleased(evt) def onCommand(self, command): """Called when a command is executed""" for listener in self.listeners["Command"]: listener.onCommand(command) def onToolsClick(self): """Called when the tools button has been clicked""" for listener in self.listeners["ConsoleCommand"]: listener.onToolsClick() def onConsoleCommand(self, command): """Called when a console command is executed""" for listener in self.listeners["ConsoleCommand"]: listener.onConsoleCommand(command) def onWidgetAction(self, evt): """Called when a widget action is executed""" for listener in self.listeners["Widget"]: listener.onWidgetAction(evt)