Mercurial > fife-parpg
view engine/extensions/pychan/fonts.py @ 164:5b04a7d3ded6
typo fix
some missing event (de)registrations
ability to capture one event multiple times (instead of only having one slot, we have groups and each group has an own slot, the default group is "default" so we are backward compatible
author | spq@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Wed, 15 Oct 2008 14:57:04 +0000 |
parents | 9a1529f9625e |
children | 54bfd1015b35 |
line wrap: on
line source
# coding: utf-8 # Font handling from exceptions import * class Font(object): def __init__(self,name,get): from manager import Manager self.font = None self.name = name self.typename = get("type") self.source = get("source") self.row_spacing = int(get("row_spacing",0)) self.glyph_spacing = int(get("glyph_spacing",0)) if self.typename == "truetype": self.size = int(get("size")) self.antialias = int(get("antialias",1)) self.color = map(int,get("color","255,255,255").split(',')) self.font = Manager.manager.guimanager.createFont(self.source,self.size,"") if self.font is None: raise InitializationError("Could not load font %s" % name) self.font.setAntiAlias(self.antialias) self.font.setColor(*self.color) else: raise InitializationError("Unsupported font type %s" % self.typename) self.font.setRowSpacing( self.row_spacing ) self.font.setGlyphSpacing( self.glyph_spacing ) @staticmethod def loadFromFile(filename): """ Static method to load font definitions out of a PyChan config file. """ import ConfigParser fontdef = ConfigParser.ConfigParser() fontdef.read(filename) sections = [section for section in fontdef.sections() if section.startswith("Font/")] fonts = [] for section in sections: name = section[5:] def _get(name,default=None): if fontdef.has_option(section,name): return fontdef.get(section,name) return default fonts.append( Font(name,_get) ) return fonts def __str__(self): return "Font(source='%s')" % self.source def __repr__(self): return "<Font(source='%s') at %x>" % (self.source,id(self)) def loadFonts(filename): """ Load fonts from a config file. These are then available via their name. """ from manager import Manager for font in Font.loadFromFile(filename): Manager.manager.addFont(font)