Mercurial > fife-parpg
view demos/shooter/scripts/ships/shipbase.py @ 697:ecaa4d98f05f tip
Abstracted the GUI code and refactored the GUIChan-specific code into its own module.
* Most of the GUIChan code has been refactored into its own gui/guichan module. However, references to the GuiFont class still persist in the Engine and GuiManager code and these will need further refactoring.
* GuiManager is now an abstract base class which specific implementations (e.g. GUIChan) should subclass.
* The GUIChan GUI code is now a concrete implementation of GuiManager, most of which is in the new GuiChanGuiManager class.
* The GUI code in the Console class has been refactored out of the Console and into the GUIChan module as its own GuiChanConsoleWidget class. The rest of the Console class related to executing commands was left largely unchanged.
* Existing client code may need to downcast the GuiManager pointer received from FIFE::Engine::getGuiManager() to GuiChanGuiManager, since not all functionality is represented in the GuiManager abstract base class. Python client code can use the new GuiChanGuiManager.castTo static method for this purpose.
author | M. George Hansen <technopolitica@gmail.com> |
---|---|
date | Sat, 18 Jun 2011 00:28:40 -1000 |
parents | 5ff83f209333 |
children |
line wrap: on
line source
# -*- coding: utf-8 -*- # #################################################################### # Copyright (C) 2005-2010 by the FIFE team # http://www.fifengine.net # This file is part of FIFE. # # FIFE is free software; you can redistribute it and/or # modify it under the terms of the GNU Lesser General Public # License as published by the Free Software Foundation; either # version 2.1 of the License, or (at your option) any later version. # # This library 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 # Lesser General Public License for more details. # # You should have received a copy of the GNU Lesser General Public # License along with this library; if not, write to the # Free Software Foundation, Inc., # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA # #################################################################### from math import sqrt from fife import fife from scripts.common.baseobject import * from scripts.weapons import Weapon class ShipActionListener(fife.InstanceActionListener): """ This class is an action listener that listens for instance actions that are complete. It is used in this demo to specify what should happen after the object has completed flashing or exploding. There should be an instance of this listener for every ship that you want to be removed from the scene after exploding. """ def __init__(self, ship): """ @param ship The ship that this actionlistener belongs to. """ fife.InstanceActionListener.__init__(self) self._ship = ship self._ship.instance.addActionListener(self) def onInstanceActionFinished(self, instance, action): if action.getId() == 'flash': if self._ship._flashing and self._ship._flashnumber > 0: self._ship.instance.act('flash', self._ship.instance.getFacingLocation()) self._ship._flashnumber -= 1 else: self._ship._flashing = False self._ship._flashnumber = 0 if action.getId() == 'explode' and not self._ship.type == SHTR_PLAYER: self._ship.removeFromScene() class Ship(SpaceObject): """ Ship This is the base ship object. The Player and Enemy ship classes inherit this class. This class extends SpaceObject by allowing Weapons to be attached to the object as well as hit points. """ def __init__(self, scene, name, findInstance=True): """ @param scene: A reference to the Scene @type scene: L{Scene} @param name: The name of the ship @type name: C{string} @param findInstance: True if the instance you are looking for is already loaded False if you want to load the instance yourself @type findInstance: C{boolean} """ super(Ship, self).__init__(scene, name, findInstance) self._weapon = None self._flashnumber = 0 self._flashing = False self._hitpoints = 0 self._scorevalue = 0 self._hitclip = self._scene.soundmanager.createSoundEmitter("sounds/hit.ogg") self._explodclip = self._scene.soundmanager.createSoundEmitter("sounds/explode.ogg") def _setWeapon(self, weapon): self._weapon = weapon def _getWeapon(self): return self._weapon def flash(self, number): """ Playes the flash animation (or action) the specified number of times @param number: An integer specifying the number of times to play the flash animation """ if self._running: self._instance.act('flash', self._instance.getFacingLocation()) self._flashnumber = number self._flashing = True def fire(self, direction): """ Fires the current weapon in the specified direction @param direction: A L{fife.DoublePoint()} specifying the direction to fire """ if self._weapon and self._hitpoints > 0: return self._weapon.fire(direction) return None def applyHit(self, hp): """ Removes the specified number of hit points. Destroys the ship if necessary. @param hp: The number of hit points to remove from the ship. """ self._hitpoints -= hp if self._hitpoints <= 0: self.destroy() else: self._hitclip.play() def destroy(self): """ Plays the explode animation (or action) """ if self._running: self._instance.act('explode', self._instance.getFacingLocation()) location = self.location.getExactLayerCoordinates() self._explodclip.position = (location.x, location.y) self._explodclip.play() super(Ship, self).destroy() def _getHitPoints(self): return self._hitpoints def _setHitPoints(self, hp): self._hitpoints = hp def _getScoreValue(self): return self._scorevalue def _setScoreValue(self, value): self._scorevalue = value weapon = property(_getWeapon, _setWeapon) hitpoints = property(_getHitPoints, _setHitPoints) scorevalue = property(_getScoreValue, _setScoreValue)