Some cleanups
This commit is contained in:
parent
126ed5840f
commit
4c80db6da0
@ -8,18 +8,15 @@ import rsvg
|
|||||||
from sugar.util import GObjectSingletonMeta
|
from sugar.util import GObjectSingletonMeta
|
||||||
from sugar.canvas.IconColor import IconColor
|
from sugar.canvas.IconColor import IconColor
|
||||||
|
|
||||||
class _Icon:
|
_ICON_SIZE = 48
|
||||||
def __init__(self, data, size):
|
|
||||||
self.data = data
|
|
||||||
self.size = size
|
|
||||||
|
|
||||||
class _IconCache:
|
class _IconCache:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self._icons = {}
|
self._icons = {}
|
||||||
|
|
||||||
def _create_icon(self, name, color, size):
|
def _create_icon(self, name, color):
|
||||||
theme = gtk.icon_theme_get_default()
|
theme = gtk.icon_theme_get_default()
|
||||||
info = theme.lookup_icon(name, size, 0)
|
info = theme.lookup_icon(name, _ICON_SIZE, 0)
|
||||||
icon_file = open(info.get_filename(), 'r')
|
icon_file = open(info.get_filename(), 'r')
|
||||||
data = icon_file.read()
|
data = icon_file.read()
|
||||||
icon_file.close()
|
icon_file.close()
|
||||||
@ -37,14 +34,14 @@ class _IconCache:
|
|||||||
style = '.shape-and-fill {fill:%s; stroke:%s;}' % (fill, stroke)
|
style = '.shape-and-fill {fill:%s; stroke:%s;}' % (fill, stroke)
|
||||||
data = re.sub('\.shape-and-fill \{.*\}', style, data)
|
data = re.sub('\.shape-and-fill \{.*\}', style, data)
|
||||||
|
|
||||||
return _Icon(data, info.get_base_size())
|
return data
|
||||||
|
|
||||||
def get_icon(self, name, color, size):
|
def get_icon(self, name, color):
|
||||||
key = (name, color.get_fill_color(), size)
|
key = (name, color.get_fill_color())
|
||||||
if self._icons.has_key(key):
|
if self._icons.has_key(key):
|
||||||
icon = self._icons[key]
|
icon = self._icons[key]
|
||||||
else:
|
else:
|
||||||
icon = self._create_icon(name, color, size)
|
icon = self._create_icon(name, color)
|
||||||
self._icons[key] = icon
|
self._icons[key] = icon
|
||||||
return icon
|
return icon
|
||||||
|
|
||||||
@ -64,10 +61,10 @@ class IconView(goocanvas.ItemViewSimple, goocanvas.ItemView):
|
|||||||
|
|
||||||
cr.save()
|
cr.save()
|
||||||
|
|
||||||
#if self.item.transform != None:
|
# if self.item.transform != None:
|
||||||
# cr.transform(self.item.transform)
|
# cr.transform(self.item.transform)
|
||||||
#if self.transform != None:
|
# if self.transform != None:
|
||||||
# cr.transform(self.transform)
|
# cr.transform(self.transform)
|
||||||
|
|
||||||
[user_x, user_y] = cr.device_to_user(x, y)
|
[user_x, user_y] = cr.device_to_user(x, y)
|
||||||
if user_x < self.item.x or \
|
if user_x < self.item.x or \
|
||||||
@ -86,10 +83,10 @@ class IconView(goocanvas.ItemViewSimple, goocanvas.ItemView):
|
|||||||
|
|
||||||
cr.save()
|
cr.save()
|
||||||
|
|
||||||
#if self.item.transform != None:
|
# if self.item.transform != None:
|
||||||
# cr.transform(self.item.transform)
|
# cr.transform(self.item.transform)
|
||||||
#if self.transform != None:
|
# if self.transform != None:
|
||||||
# cr.transform(self.transform)
|
# cr.transform(self.transform)
|
||||||
|
|
||||||
bounds = goocanvas.Bounds()
|
bounds = goocanvas.Bounds()
|
||||||
bounds.x1 = self.item.x
|
bounds.x1 = self.item.x
|
||||||
@ -108,24 +105,20 @@ class IconView(goocanvas.ItemViewSimple, goocanvas.ItemView):
|
|||||||
theme = gtk.icon_theme_get_default()
|
theme = gtk.icon_theme_get_default()
|
||||||
info = theme.lookup_icon(self.item.icon_name, self.item.size, 0)
|
info = theme.lookup_icon(self.item.icon_name, self.item.size, 0)
|
||||||
handle = rsvg.Handle(file=info.get_filename())
|
handle = rsvg.Handle(file=info.get_filename())
|
||||||
icon_size = info.get_base_size()
|
|
||||||
else:
|
else:
|
||||||
icon = IconView._icon_cache.get_icon(self.item.icon_name,
|
icon = IconView._icon_cache.get_icon(self.item.icon_name,
|
||||||
self.item.color,
|
self.item.color)
|
||||||
self.item.size)
|
handle = rsvg.Handle(data=icon)
|
||||||
handle = rsvg.Handle(data=icon.data)
|
|
||||||
icon_size = icon.size
|
|
||||||
|
|
||||||
|
|
||||||
cr.save()
|
cr.save()
|
||||||
|
|
||||||
#if self.item.transform != None:
|
# if self.item.transform != None:
|
||||||
# cr.transform(self.item.transform)
|
# cr.transform(self.item.transform)
|
||||||
#if self.transform != None:
|
# if self.transform != None:
|
||||||
# cr.transform(self.transform)
|
# cr.transform(self.transform)
|
||||||
|
|
||||||
cr.translate(self.item.x, self.item.y)
|
cr.translate(self.item.x, self.item.y)
|
||||||
scale_factor = float(self.item.size) / float(icon_size)
|
scale_factor = float(self.item.size) / float(_ICON_SIZE)
|
||||||
cr.scale(scale_factor, scale_factor)
|
cr.scale(scale_factor, scale_factor)
|
||||||
|
|
||||||
handle.render_cairo(cr)
|
handle.render_cairo(cr)
|
||||||
@ -160,8 +153,6 @@ class IconItem(goocanvas.ItemSimple, goocanvas.Item):
|
|||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
self.x = 0.0
|
self.x = 0.0
|
||||||
self.y = 0.0
|
self.y = 0.0
|
||||||
self.width = 0.0
|
|
||||||
self.height = 0.0
|
|
||||||
|
|
||||||
goocanvas.ItemSimple.__init__(self, **kwargs)
|
goocanvas.ItemSimple.__init__(self, **kwargs)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user