Mercurial > parpg-core
view src/parpg/font.py @ 12:d60f1dab8469
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 | 1fd2201f5c36 |
children | 59c9ce2b8351 |
line wrap: on
line source
import os from fife.extensions.pychan.fonts import Font from fife.extensions.pychan.internal import get_manager class PARPGFont(Font): """ Font class for PARPG This class behaves identical to PyChan's Font class except in initialization. Ratherthan take a name and a get object, this class takes a fontdef and settings object as explained below. This class is necessary because the original Font class was too restrictive on how it accepted objects @param fontdef: defines the font's name, size, type, and optionally row spacing as well as glyph spacing. @type fontdef: dictionary @param settings: settings object used to dynamically determine the font's source location @type settings: parpg.settings.Settings object """ def __init__(self, fontdef, settings): self.font = None self.name = fontdef['name'] self.typename = fontdef['typename'] if self.typename == 'truetype': self.filename = '{0}.ttf'.format(self.name.lower().split('_')[0]) self.source = '/'.join(['fonts', self.filename]) self.row_spacing = fontdef.get('row_spacing', 0) self.glyph_spacing = fontdef.get('glyph_spacing', 0) if self.typename == 'truetype': self.size = fontdef['size'] self.antialias = fontdef['antialias'] self.color = fontdef.get('color', [255, 255, 255]) manager = get_manager().hook.engine.getGuiManager() self.font = manager.createFont(self.source, self.size, '') if not self.font: raise InitializationError('Could not load font ' '{0}'.format(self.name)) self.font.setAntiAlias(self.antialias) self.font.setColor(*self.color) else: raise InitializationError('Unsupported font type ' '{0}'.format(self.typename)) self.font.setRowSpacing(self.row_spacing) self.font.setGlyphSpacing(self.glyph_spacing)