X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=skin.py;h=3497cc115f12d517a4c68857ea06c14e5f25bd72;hb=6c2d3fc303542b7f77f4350974acf781a1b91c30;hp=e7c84c424bf1badad3db0671a0dda6d859fb4162;hpb=f01049eaf5c70d53a3c8f3309486bec771b321f4;p=vuplus_dvbapp diff --git a/skin.py b/skin.py index e7c84c4..3497cc1 100644 --- a/skin.py +++ b/skin.py @@ -72,6 +72,7 @@ def applySingleAttribute(guiObject, desktop, attrib, value): guiObject.setZPosition(int(value)) elif attrib == "pixmap": ptr = loadPNG(value) + # that __deref__ still scares me! desktop.makeCompatiblePixmap(ptr.__deref__()) guiObject.setPixmap(ptr.__deref__()) # guiObject.setPixmapFromFile(value) @@ -135,6 +136,12 @@ def applySingleAttribute(guiObject, desktop, attrib, value): }[value]) elif attrib == "enableWrapAround": guiObject.setWrapAround(True) + elif attrib == "pointer": + (name, pos) = value.split(':') + pos = parsePosition(pos) + ptr = loadPNG(name) + desktop.makeCompatiblePixmap(ptr.__deref__()) + guiObject.setPointer(ptr.__deref__(), pos) elif attrib != 'name': print "unsupported attribute " + attrib + "=" + value except int: @@ -203,13 +210,12 @@ def readSkin(screen, skin, name, desktop): myscreen = x del skin - if myscreen is None: - # try embedded skin - print screen.__dict__ - if "parsedSkin" in screen.__dict__: - myscreen = screen.parsedSkin - elif "skin" in screen.__dict__: - myscreen = screen.parsedSkin = xml.dom.minidom.parseString(screen.skin).childNodes[0] + # try embedded skin + myscreen = myscreen or getattr(screen, "parsedSkin", None) + + # try uncompiled embedded skin + if myscreen is None and getattr(screen, "skin", None): + myscreen = screen.parsedSkin = xml.dom.minidom.parseString(screen.skin).childNodes[0] assert myscreen is not None, "no skin for screen '" + name + "' found!"