Mercurial > fife-parpg
diff engine/extensions/pychan/fonts.py @ 0:4a0efb7baf70
* Datasets becomes the new trunk and retires after that :-)
author | mvbarracuda@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Sun, 29 Jun 2008 18:44:17 +0000 |
parents | |
children | 9a1529f9625e |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/engine/extensions/pychan/fonts.py Sun Jun 29 18:44:17 2008 +0000 @@ -0,0 +1,69 @@ +# 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) +