2007-12-11 02:50:45 -08:00
|
|
|
import os
|
2009-01-21 01:51:06 -08:00
|
|
|
#import cluttergtk
|
2007-12-16 04:21:40 -08:00
|
|
|
import clutter
|
2007-12-21 03:39:50 -08:00
|
|
|
import pygtk
|
|
|
|
import gtk
|
2008-05-10 18:21:08 -07:00
|
|
|
from ui_elements.image_frame import ImageFrame
|
2008-06-29 04:11:33 -07:00
|
|
|
from ui_elements.rounded_rectangle import RoundedRectangle
|
2009-01-21 01:51:06 -08:00
|
|
|
from ui_elements.gloss_texture import GlossTexture
|
2007-12-11 02:50:45 -08:00
|
|
|
from xml.dom import minidom
|
|
|
|
|
2009-01-21 01:51:06 -08:00
|
|
|
|
2007-12-11 02:50:45 -08:00
|
|
|
class ThemeMgr:
|
2008-02-24 12:42:52 -08:00
|
|
|
theme_dir = "themes/"
|
|
|
|
|
2007-12-11 02:50:45 -08:00
|
|
|
defaultTheme = "default"
|
|
|
|
currentTheme = "default"
|
2008-06-26 22:57:36 -07:00
|
|
|
currentTheme = "Gloxygen"
|
2007-12-11 02:50:45 -08:00
|
|
|
|
2008-06-26 22:57:36 -07:00
|
|
|
def __init__(self, glossMgr, theme=None):
|
2008-01-08 02:44:51 -08:00
|
|
|
self.stage = glossMgr.stage
|
|
|
|
self.glossMgr = glossMgr
|
2007-12-11 02:50:45 -08:00
|
|
|
self.docs = []
|
|
|
|
self.default_docs = []
|
|
|
|
|
2008-06-26 22:57:36 -07:00
|
|
|
#Check the db for a theme setting, if it doesn't exist, we create an entry using the current theme
|
|
|
|
if not theme is None:
|
|
|
|
self.currentTheme = theme
|
|
|
|
glossMgr.dbMgr.set_setting("gloss_theme", self.currentTheme)
|
|
|
|
else:
|
|
|
|
db_theme = glossMgr.dbMgr.get_setting("gloss_theme")
|
|
|
|
if db_theme is None:
|
|
|
|
glossMgr.dbMgr.set_setting("gloss_theme", self.currentTheme)
|
|
|
|
else:
|
|
|
|
self.currentTheme = db_theme
|
|
|
|
|
2008-02-24 12:42:52 -08:00
|
|
|
current_theme_dir = self.theme_dir + self.currentTheme
|
|
|
|
self.importDocs(current_theme_dir, self.docs)
|
2007-12-11 02:50:45 -08:00
|
|
|
#If the current theme is the default theme, we just use the one list, else create a second one
|
|
|
|
if self.currentTheme == self.defaultTheme:
|
|
|
|
self.default_docs = self.docs
|
|
|
|
else:
|
2008-02-24 12:42:52 -08:00
|
|
|
current_theme_dir = self.theme_dir + self.defaultTheme
|
|
|
|
self.importDocs(current_theme_dir, self.default_docs)
|
2007-12-11 02:50:45 -08:00
|
|
|
|
|
|
|
def importDocs(self, dir, docs):
|
|
|
|
file_list = os.listdir(dir)
|
|
|
|
file_list = filter(self.filterXMLFile, file_list)
|
|
|
|
|
|
|
|
for file in file_list:
|
|
|
|
conf_file = dir + "/" + file
|
2008-01-23 14:21:28 -08:00
|
|
|
#print conf_file
|
2007-12-11 02:50:45 -08:00
|
|
|
docs.append(minidom.parse(conf_file))
|
|
|
|
|
|
|
|
#Filter function for fiding XML files
|
|
|
|
def filterXMLFile(self, filename):
|
|
|
|
xml_file_types = ["xml", "XML"]
|
|
|
|
extension = filename[-3:]
|
|
|
|
|
|
|
|
if extension in xml_file_types:
|
|
|
|
return True
|
|
|
|
else:
|
|
|
|
return False
|
2007-12-16 04:21:40 -08:00
|
|
|
|
|
|
|
#Loops through firstly the current theme files, then the default ones looking for an element of 'element_type' with an ID of 'element_id'
|
|
|
|
def search_docs(self, element_type, element_id):
|
2007-12-11 02:50:45 -08:00
|
|
|
texture_element = None
|
2007-12-16 04:21:40 -08:00
|
|
|
|
2007-12-11 02:50:45 -08:00
|
|
|
#First loop through the current theme docs
|
|
|
|
for doc in self.docs:
|
2007-12-16 04:21:40 -08:00
|
|
|
temp_element = self.find_element(doc.getElementsByTagName(element_type), "id", element_id)
|
2007-12-11 02:50:45 -08:00
|
|
|
if not temp_element is None:
|
|
|
|
texture_element = temp_element
|
|
|
|
|
2007-12-16 04:21:40 -08:00
|
|
|
#If texture_element is still equal to None, we check the default theme
|
2007-12-11 02:50:45 -08:00
|
|
|
if (texture_element is None) and (not self.docs == self.default_docs):
|
|
|
|
for doc in self.default_docs:
|
2007-12-16 04:21:40 -08:00
|
|
|
temp_element = self.find_element(doc.getElementsByTagName(element_type), "id", element_id)
|
2007-12-11 02:50:45 -08:00
|
|
|
if not temp_element is None:
|
|
|
|
texture_element = temp_element
|
2007-12-16 04:21:40 -08:00
|
|
|
|
|
|
|
return texture_element
|
|
|
|
|
|
|
|
#Simple utity function that is used by 'search_docs' to find a matching element in an array of elements
|
2007-12-11 02:50:45 -08:00
|
|
|
def find_element(self, elements, attribute, value):
|
|
|
|
for element in elements:
|
|
|
|
val = element.getAttribute(attribute)
|
|
|
|
if val == value:
|
2007-12-16 04:21:40 -08:00
|
|
|
#print val
|
2007-12-11 02:50:45 -08:00
|
|
|
return element
|
2007-12-16 04:21:40 -08:00
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
#Search through an element to find a value
|
|
|
|
#Specifying the element name in the format 'level1. value' will result in the function looping
|
|
|
|
def find_child_value(self, nodeList, value):
|
2007-12-17 05:19:22 -08:00
|
|
|
#print "No Nodes: " + str(len(nodeList))
|
2007-12-16 04:21:40 -08:00
|
|
|
#Check whether the value is in the form "xxx.y"
|
|
|
|
values = value.find(".")
|
|
|
|
if not values == -1:
|
|
|
|
desiredTagName = value[:values]
|
|
|
|
#print "test " + value[(values+1):]
|
|
|
|
#print "blah" + tagName
|
|
|
|
for subnode in nodeList:
|
|
|
|
if subnode.nodeType == subnode.ELEMENT_NODE:
|
2007-12-17 05:19:22 -08:00
|
|
|
#print "Tag Name: " + subnode.tagName
|
2007-12-16 04:21:40 -08:00
|
|
|
if subnode.tagName == desiredTagName:
|
|
|
|
# call function again to get children
|
|
|
|
return self.find_child_value(subnode.childNodes, value[(values+1):])
|
|
|
|
else:
|
|
|
|
for subnode in nodeList:
|
2007-12-17 05:19:22 -08:00
|
|
|
if (subnode.nodeType == subnode.TEXT_NODE) and (not subnode.nextSibling is None):
|
2007-12-16 04:21:40 -08:00
|
|
|
subnode = subnode.nextSibling
|
|
|
|
if subnode.localName == value:
|
|
|
|
valueNode = subnode.childNodes[0]
|
|
|
|
return valueNode.data
|
2007-12-17 05:19:22 -08:00
|
|
|
|
|
|
|
#If we get to here, we hath failed
|
|
|
|
return None
|
|
|
|
|
|
|
|
#Search through an element to find an attribute
|
|
|
|
#This is basically the same as find_child_value except it gets an attribute
|
|
|
|
def find_attribute_value(self, nodeList, tagName, attributeID):
|
|
|
|
#print "No Nodes: " + str(len(nodeList))
|
|
|
|
#Check whether the value is in the form "xxx.y"
|
|
|
|
values = tagName.find(".")
|
|
|
|
if not values == -1:
|
|
|
|
desiredTagName = tagName[:values]
|
|
|
|
#print "test " + value[(values+1):]
|
|
|
|
#print "blah" + tagName
|
|
|
|
for subnode in nodeList:
|
|
|
|
if subnode.nodeType == subnode.ELEMENT_NODE:
|
|
|
|
#print "Tag Name: " + subnode.tagName
|
|
|
|
if subnode.tagName == desiredTagName:
|
|
|
|
# call function again to get children
|
|
|
|
return self.find_attribute_value(subnode.childNodes, tagName[(values+1):])
|
|
|
|
else:
|
|
|
|
for subnode in nodeList:
|
|
|
|
if subnode.localName == tagName:
|
|
|
|
#print "keys: " + str(len(subnode.attributes.values()))
|
|
|
|
if len(subnode.attributes.values()) > 0:
|
|
|
|
return subnode.attributes[attributeID].value
|
|
|
|
|
|
|
|
#If we get to here, we hath failed
|
|
|
|
return None
|
|
|
|
|
2008-01-09 04:27:33 -08:00
|
|
|
#Given an element, returns a subset of it based on the tag name of the subset
|
|
|
|
def get_subnode(self, element, tag_name):
|
|
|
|
for node in element:
|
|
|
|
if node.nodeType == node.ELEMENT_NODE:
|
|
|
|
if node.tagName == tag_name:
|
|
|
|
return node.childNodes
|
|
|
|
#Fail!
|
|
|
|
return None
|
|
|
|
|
2007-12-17 05:19:22 -08:00
|
|
|
|
|
|
|
#*********************************************************************
|
|
|
|
# The methods below all relate to fulfilling requests for actors
|
|
|
|
|
|
|
|
#This is the generic function for setting up an actor.
|
|
|
|
#It sets up all the 'common' properties:
|
2007-12-21 03:39:50 -08:00
|
|
|
#Currently: size, position, opacity
|
2008-01-03 04:26:38 -08:00
|
|
|
def get_value(self, type, name, property):
|
|
|
|
element = self.search_docs(type, name).childNodes
|
|
|
|
#Quick check to make sure we found something
|
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
|
|
|
return self.find_child_value(element, property)
|
|
|
|
|
2007-12-17 05:19:22 -08:00
|
|
|
def setup_actor(self, actor, element, parent):
|
|
|
|
#Set the size
|
|
|
|
#First setup the parent
|
|
|
|
relativeTo = str(self.find_attribute_value(element, "dimensions", "type"))
|
|
|
|
if relativeTo == "relativeToStage":
|
|
|
|
parent = self.stage
|
2008-01-09 18:51:37 -08:00
|
|
|
elif relativeTo == "relativeToParent":
|
2008-05-05 07:09:45 -07:00
|
|
|
if parent is None: parent = actor.get_parent()
|
2008-01-09 18:51:37 -08:00
|
|
|
elif relativeTo == "relativeToSelf":
|
|
|
|
parent = actor
|
2007-12-17 05:19:22 -08:00
|
|
|
|
2008-04-06 05:22:53 -07:00
|
|
|
|
2008-01-09 04:27:33 -08:00
|
|
|
(width, height) = self.get_dimensions(element, parent)
|
2008-01-09 18:51:37 -08:00
|
|
|
if (not height is None) and (not height == "default"):
|
|
|
|
if height == "relative":
|
2009-01-21 01:51:06 -08:00
|
|
|
if actor.get_width() == 0:
|
|
|
|
height = 0
|
|
|
|
else:
|
|
|
|
xy_ratio = float(actor.get_height()) / float(actor.get_width())
|
|
|
|
height = int(width * xy_ratio)
|
2008-01-09 18:51:37 -08:00
|
|
|
actor.set_height(height)
|
2008-05-10 18:55:35 -07:00
|
|
|
if (not width is None) and (not width == "default"):
|
|
|
|
actor.set_width(width)
|
2008-01-09 04:27:33 -08:00
|
|
|
|
|
|
|
#Set the position of the actor
|
|
|
|
(x,y) = (0,0)
|
|
|
|
#Get the parent
|
|
|
|
relativeTo = str(self.find_attribute_value(element, "position", "type"))
|
|
|
|
if relativeTo == "relativeToStage":
|
|
|
|
parent = self.stage
|
|
|
|
elif not (relativeTo == "relativeToParent"):
|
|
|
|
parent = None
|
|
|
|
|
|
|
|
|
2008-06-07 07:05:57 -07:00
|
|
|
(x, y) = self.get_position(element, parent, actor=actor)
|
2008-01-09 04:27:33 -08:00
|
|
|
actor.set_position(int(x), int(y))
|
|
|
|
|
|
|
|
#now set the opacity
|
|
|
|
opacity = self.find_child_value(element, "opacity")
|
|
|
|
if not opacity is None:
|
|
|
|
opacity = int(opacity)
|
|
|
|
actor.set_opacity(opacity)
|
|
|
|
|
|
|
|
def get_dimensions(self, element, parent):
|
2007-12-17 05:19:22 -08:00
|
|
|
width = self.find_child_value(element, "dimensions.width")
|
|
|
|
if (not width == "default") and (not width is None):
|
|
|
|
if width[-1] == "%":
|
|
|
|
#Quick check on parent
|
|
|
|
if parent is None:
|
2008-05-05 07:09:45 -07:00
|
|
|
print "Theme error (get_dimensions width): parent must be specified when using percentage values"
|
|
|
|
return (None, None)
|
2007-12-17 05:19:22 -08:00
|
|
|
|
|
|
|
width = (float(width[:-1]) / 100.0) * parent.get_width()
|
|
|
|
#print "width: " + str(width)
|
2008-01-03 04:26:38 -08:00
|
|
|
width = int(width)
|
2008-01-09 18:51:37 -08:00
|
|
|
else:
|
|
|
|
width = None
|
2007-12-17 05:19:22 -08:00
|
|
|
height = self.find_child_value(element, "dimensions.height")
|
2008-01-09 18:51:37 -08:00
|
|
|
if (not height == "default") and (not height is None) and (not height == "relative"):
|
2007-12-17 05:19:22 -08:00
|
|
|
if height[-1] == "%":
|
|
|
|
height = (float(height[:-1]) / 100.0) * parent.get_height()
|
2008-01-03 04:26:38 -08:00
|
|
|
height = int(height)
|
2008-04-06 05:22:53 -07:00
|
|
|
#elif height == "relative":
|
|
|
|
# print "Found relative size"
|
|
|
|
elif not height == "relative":
|
2008-01-09 18:51:37 -08:00
|
|
|
height = None
|
|
|
|
|
2008-01-09 04:27:33 -08:00
|
|
|
return (width, height)
|
|
|
|
|
|
|
|
#Given an element, returns (x, y) coords for it
|
2008-06-07 07:05:57 -07:00
|
|
|
def get_position(self, element, parent, actor=None):
|
2007-12-21 03:39:50 -08:00
|
|
|
#set the x coord
|
|
|
|
x = self.find_child_value(element, "position.x")
|
|
|
|
if (not x == "default") and (not x is None):
|
|
|
|
if x[-1] == "%":
|
|
|
|
#Quick check on parent
|
|
|
|
if parent is None:
|
2008-05-05 07:09:45 -07:00
|
|
|
print "Theme error (get_position x): type must be specified when using percentage values"
|
2007-12-21 03:39:50 -08:00
|
|
|
return None
|
2008-05-28 15:37:55 -07:00
|
|
|
#this is a hack to get around the cases where the parent is a group (And hence has no valid wdith value)
|
|
|
|
if parent.get_width() == 0: x = (float(x[:-1]) / 100.0) * parent.width
|
|
|
|
else: x = (float(x[:-1]) / 100.0) * parent.get_width()
|
2007-12-21 03:39:50 -08:00
|
|
|
#print "width: " + str(width)
|
|
|
|
elif x == "center":
|
|
|
|
#Quick check on parent
|
|
|
|
if parent is None:
|
|
|
|
print "Theme error: type must be specified when using 'center' values"
|
|
|
|
return None
|
2008-05-28 15:37:55 -07:00
|
|
|
#this is a hack to get around the cases where the parent is a group (And hence has no valid wdith value)
|
|
|
|
if parent.get_width() == 0: x = (parent.width - actor.get_width())/2
|
|
|
|
else: x = (parent.get_width() - actor.get_width())/2
|
2007-12-21 03:39:50 -08:00
|
|
|
else:
|
|
|
|
x = 0
|
|
|
|
|
|
|
|
#set the y coord
|
|
|
|
y = self.find_child_value(element, "position.y")
|
|
|
|
if (not y == "default") and (not y is None):
|
|
|
|
if y[-1] == "%":
|
|
|
|
#Quick check on parent
|
|
|
|
if parent is None:
|
2008-05-05 07:09:45 -07:00
|
|
|
print "Theme error (get_position y): type must be specified when using percentage values"
|
2007-12-21 03:39:50 -08:00
|
|
|
return None
|
2008-05-28 15:37:55 -07:00
|
|
|
#this is a hack to get around the cases where the parent is a group (And hence has no valid wdith value)
|
|
|
|
if parent.get_height() == 0: y = (float(y[:-1]) / 100.0) * parent.height
|
|
|
|
else: y = (float(y[:-1]) / 100.0) * parent.get_height()
|
2007-12-21 03:39:50 -08:00
|
|
|
#print "width: " + str(width)
|
|
|
|
elif y == "center":
|
|
|
|
#Quick check on parent
|
|
|
|
if parent is None:
|
|
|
|
print "Theme error: type must be specified when using 'center' values"
|
|
|
|
return None
|
2008-05-28 15:37:55 -07:00
|
|
|
#this is a hack to get around the cases where the parent is a group (And hence has no valid wdith value)
|
|
|
|
if parent.get_height() == 0: y = (parent.height - actor.get_height)/2
|
|
|
|
else: y = (parent.get_height() - actor.get_height())/2
|
2007-12-21 03:39:50 -08:00
|
|
|
else:
|
|
|
|
y = 0
|
2008-01-09 04:27:33 -08:00
|
|
|
|
|
|
|
return (int(x), int(y))
|
2007-12-17 05:19:22 -08:00
|
|
|
|
2008-05-28 15:37:55 -07:00
|
|
|
def get_colour(self, element, name, subnode = False):
|
2008-05-22 05:41:04 -07:00
|
|
|
if element is None:
|
|
|
|
element = self.search_docs("colour", name).childNodes
|
|
|
|
#Quick check to make sure we found something
|
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
2008-05-28 15:37:55 -07:00
|
|
|
if subnode:
|
|
|
|
if self.find_child_value(element, "colour") is None: return None
|
|
|
|
r = int(self.find_child_value(element, "colour.r"))
|
|
|
|
g = int(self.find_child_value(element, "colour.g"))
|
|
|
|
b = int(self.find_child_value(element, "colour.b"))
|
|
|
|
else:
|
|
|
|
if self.find_child_value(element, "r") is None: return None
|
|
|
|
r = int(self.find_child_value(element, "r"))
|
|
|
|
g = int(self.find_child_value(element, "g"))
|
|
|
|
b = int(self.find_child_value(element, "b"))
|
2008-05-22 05:41:04 -07:00
|
|
|
|
|
|
|
colour = clutter.Color(r, g, b)
|
|
|
|
return colour
|
|
|
|
|
2008-06-06 17:29:53 -07:00
|
|
|
def get_texture(self, name, parent=None, texture=None, element=None):
|
2007-12-17 05:19:22 -08:00
|
|
|
texture_src = None
|
2007-12-31 17:21:28 -08:00
|
|
|
if texture is None:
|
2009-01-21 01:51:06 -08:00
|
|
|
texture = GlossTexture()
|
2008-06-06 17:29:53 -07:00
|
|
|
if parent is None:
|
|
|
|
parent = self.stage
|
2007-12-17 05:19:22 -08:00
|
|
|
|
2008-05-05 07:09:45 -07:00
|
|
|
#Element can be supplied but if not, we search through everything
|
|
|
|
if element is None: element = self.search_docs("texture", name).childNodes
|
|
|
|
#Quick check to make sure we've got something
|
2007-12-17 05:19:22 -08:00
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
2007-12-21 03:39:50 -08:00
|
|
|
#Setup the pixbuf
|
|
|
|
src = self.find_child_value(element, "image")
|
2008-06-29 04:11:33 -07:00
|
|
|
rect = self.find_child_value(element, "rounded_rectangle")
|
2008-01-31 12:41:26 -08:00
|
|
|
#Special case to handle no image
|
|
|
|
if src == "None":
|
|
|
|
return texture
|
2008-06-29 04:11:33 -07:00
|
|
|
elif not src is None:
|
|
|
|
src = self.theme_dir + self.currentTheme + "/" + src
|
|
|
|
pixbuf = gtk.gdk.pixbuf_new_from_file(src)
|
2009-01-21 01:51:06 -08:00
|
|
|
texture.set_from_pixbuf(pixbuf)
|
2008-06-29 04:11:33 -07:00
|
|
|
elif not rect is None:
|
|
|
|
colour_element = self.search_docs("texture", name).getElementsByTagName("texture")
|
|
|
|
colour_element = self.find_element(colour_element, "id", "rect_colour")
|
|
|
|
colour = self.get_colour(colour_element, "rect_colour", False)
|
|
|
|
texture = RoundedRectangle(20, 20, colour)
|
|
|
|
elif (src is None) and (rect is None):
|
2008-05-05 07:09:45 -07:00
|
|
|
return None
|
2008-01-31 12:41:26 -08:00
|
|
|
|
2007-12-21 03:39:50 -08:00
|
|
|
#Setup general actor properties
|
2008-05-05 07:09:45 -07:00
|
|
|
self.setup_actor(texture, element, parent)
|
2007-12-21 03:39:50 -08:00
|
|
|
|
|
|
|
return texture
|
2008-05-22 05:41:04 -07:00
|
|
|
|
2007-12-21 03:39:50 -08:00
|
|
|
|
2008-06-12 03:32:21 -07:00
|
|
|
def get_font(self, name, element=None):
|
2007-12-31 17:21:28 -08:00
|
|
|
if element is None:
|
|
|
|
element = self.search_docs("font", name).childNodes
|
|
|
|
#Quick check to make sure we found something
|
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
|
|
|
face = self.find_child_value(element, "face")
|
|
|
|
res = str(self.stage.get_width()) + "x" + str(self.stage.get_height())
|
|
|
|
|
|
|
|
size = None
|
|
|
|
defSize = None
|
|
|
|
#Loop through all the different sizes until we find the right one (or else use the default)
|
|
|
|
for node in element:
|
|
|
|
if node.nodeType == node.ELEMENT_NODE:
|
|
|
|
if node.tagName == "size":
|
|
|
|
if node.attributes["id"].value == res:
|
|
|
|
size = node.childNodes[0].data
|
|
|
|
elif node.attributes["id"].value == "default":
|
|
|
|
defSize = node.childNodes[0].data
|
|
|
|
if size is None:
|
|
|
|
size = defSize
|
|
|
|
|
|
|
|
fontString = str(face) + " " + str(size)
|
2008-05-10 18:21:08 -07:00
|
|
|
return fontString
|
|
|
|
|
|
|
|
def get_imageFrame(self, id, element = None):
|
|
|
|
if element is None:
|
|
|
|
element = self.search_docs("image_frame", id).childNodes
|
|
|
|
#Quick check to make sure we found something
|
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
|
|
|
(width, height) = self.get_dimensions(element, self.stage)
|
|
|
|
if (not width is None) and (not height is None):
|
2008-06-09 05:07:31 -07:00
|
|
|
if (width > height) or (height == "relative"):
|
2008-05-10 18:21:08 -07:00
|
|
|
size = width
|
|
|
|
else:
|
|
|
|
size = height
|
|
|
|
else:
|
|
|
|
size = 300
|
|
|
|
|
|
|
|
use_reflections = self.find_child_value(element, "use_reflections")
|
|
|
|
if not use_reflections is None:
|
|
|
|
use_reflections = (use_reflections.upper() == "TRUE")
|
|
|
|
else:
|
2008-05-13 06:45:59 -07:00
|
|
|
#Gotta have some default value.
|
2008-05-10 18:21:08 -07:00
|
|
|
use_reflections = True
|
|
|
|
|
|
|
|
quality = self.find_child_value(element, "quality")
|
|
|
|
if not quality is None:
|
|
|
|
if (quality.upper() == "FAST"):
|
|
|
|
quality = ImageFrame.QUALITY_FAST
|
|
|
|
elif (quality.upper() == "NORMAL"):
|
|
|
|
quality = ImageFrame.QUALITY_NORMAL
|
|
|
|
elif (quality.upper() == "SLOW"):
|
|
|
|
quality = ImageFrame.QUALITY_SLOW
|
|
|
|
else:
|
|
|
|
#Default value
|
|
|
|
quality = ImageFrame.QUALITY_NORMAL
|
|
|
|
else:
|
2008-05-13 06:45:59 -07:00
|
|
|
#Gotta have some default value.
|
2008-05-10 18:21:08 -07:00
|
|
|
quality = ImageFrame.QUALITY_NORMAL
|
|
|
|
|
|
|
|
#Setup the pixbuf
|
|
|
|
src = self.find_child_value(element, "image")
|
|
|
|
if src == "None":
|
|
|
|
pixbuf = None
|
|
|
|
elif src is None:
|
|
|
|
pixbuf = None
|
|
|
|
else:
|
|
|
|
src = self.theme_dir + self.currentTheme + "/" + src
|
|
|
|
pixbuf = gtk.gdk.pixbuf_new_from_file(src)
|
|
|
|
|
|
|
|
img_frame = ImageFrame(pixbuf, size, use_reflections, quality)
|
|
|
|
|
|
|
|
#Set the position of the Frame
|
|
|
|
(x,y) = (0,0)
|
|
|
|
#Get the parent
|
|
|
|
relativeTo = str(self.find_attribute_value(element, "position", "type"))
|
|
|
|
if relativeTo == "relativeToStage":
|
|
|
|
parent = self.stage
|
|
|
|
elif not (relativeTo == "relativeToParent"):
|
|
|
|
parent = None
|
|
|
|
(x, y) = self.get_position(element, parent)
|
|
|
|
img_frame.set_position(int(x), int(y))
|
|
|
|
|
2008-05-22 05:41:04 -07:00
|
|
|
return img_frame
|
|
|
|
|
|
|
|
def get_label(self, id, parent = None, element = None, label = None):
|
|
|
|
if element is None:
|
|
|
|
element = self.search_docs("label", id).childNodes
|
|
|
|
#Quick check to make sure we found something
|
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
|
|
|
if label is None: label = clutter.Label()
|
|
|
|
if parent is None: parent = self.stage
|
|
|
|
|
|
|
|
font_string = self.get_font("font", element)
|
2008-05-28 15:37:55 -07:00
|
|
|
colour = self.get_colour(element, "colour", subnode = True)
|
2008-05-22 05:41:04 -07:00
|
|
|
label.set_font_name(font_string)
|
|
|
|
|
|
|
|
self.setup_actor(label, element, parent)
|
2008-05-28 15:37:55 -07:00
|
|
|
if not colour is None: label.set_color(colour)
|
2008-05-22 05:41:04 -07:00
|
|
|
|
|
|
|
return label
|
2008-05-28 15:37:55 -07:00
|
|
|
|
|
|
|
def get_group(self, id, parent = None, element = None, group = None):
|
|
|
|
if element is None:
|
|
|
|
element = self.search_docs("group", id).childNodes
|
|
|
|
#Quick check to make sure we found something
|
|
|
|
if element is None:
|
|
|
|
return None
|
|
|
|
|
|
|
|
if group is None:
|
|
|
|
group = clutter.Group()
|
|
|
|
if parent is None:
|
|
|
|
parent = self.stage
|
|
|
|
|
2008-06-05 16:48:42 -07:00
|
|
|
#print self.find_child_value(element, "dimensions.width")
|
|
|
|
#print self.get_dimensions(element, parent)
|
2008-05-28 15:37:55 -07:00
|
|
|
self.setup_actor(group, element, parent)
|
|
|
|
(group.width, group.height) = self.get_dimensions(element, parent)
|
2008-06-05 16:48:42 -07:00
|
|
|
#print group.width
|
2008-05-28 15:37:55 -07:00
|
|
|
|
|
|
|
return group
|