Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar/graphics
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <marco@localhost.localdomain>2006-10-01 17:08:26 (GMT)
committer Marco Pesenti Gritti <marco@localhost.localdomain>2006-10-01 17:08:26 (GMT)
commitd05f1f13d325dc41674ff99020dbcb67ef78dab8 (patch)
treed945b0166003d9850a431be08257552e15eda9c5 /sugar/graphics
parentbe70008c0705093fbc666702c1bc208b91b45d36 (diff)
Start rewriting our canvas stuff to cleanup and use hippo.
Out of the build.
Diffstat (limited to 'sugar/graphics')
-rw-r--r--sugar/graphics/Makefile.am5
-rw-r--r--sugar/graphics/__init__.py0
-rw-r--r--sugar/graphics/canvasicon.py134
-rw-r--r--sugar/graphics/grid.py15
-rw-r--r--sugar/graphics/style.py13
5 files changed, 167 insertions, 0 deletions
diff --git a/sugar/graphics/Makefile.am b/sugar/graphics/Makefile.am
new file mode 100644
index 0000000..a5f8166
--- /dev/null
+++ b/sugar/graphics/Makefile.am
@@ -0,0 +1,5 @@
+sugardir = $(pythondir)/sugar/graphics
+sugar_PYTHON = \
+ __init__.py \
+ canvasicon.py \
+ grid.py
diff --git a/sugar/graphics/__init__.py b/sugar/graphics/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/sugar/graphics/__init__.py
diff --git a/sugar/graphics/canvasicon.py b/sugar/graphics/canvasicon.py
new file mode 100644
index 0000000..e8d8ea4
--- /dev/null
+++ b/sugar/graphics/canvasicon.py
@@ -0,0 +1,134 @@
+import re
+
+import gobject
+import gtk
+import hippo
+import rsvg
+import cairo
+
+from sugar.canvas.IconColor import IconColor
+
+class _IconCache:
+ def __init__(self):
+ self._icons = {}
+ self._theme = gtk.icon_theme_get_default()
+
+ def _read_icon(self, filename, color):
+ icon_file = open(filename, 'r')
+
+ if color == None:
+ return rsvg.Handle(file=filename)
+ else:
+ data = icon_file.read()
+ icon_file.close()
+
+ fill = color.get_fill_color()
+ stroke = color.get_stroke_color()
+
+ entity = '<!ENTITY fill_color "%s">' % fill
+ data = re.sub('<!ENTITY fill_color .*>', entity, data)
+
+ entity = '<!ENTITY stroke_color "%s">' % stroke
+ data = re.sub('<!ENTITY stroke_color .*>', entity, data)
+
+ return rsvg.Handle(data=data)
+
+ def get_handle(self, name, color, size):
+ info = self._theme.lookup_icon(name, int(size), 0)
+
+ if color:
+ key = (info.get_filename(), color.to_string())
+ else:
+ key = info.get_filename()
+
+ if self._icons.has_key(key):
+ icon = self._icons[key]
+ else:
+ icon = self._read_icon(info.get_filename(), color)
+ self._icons[key] = icon
+ return icon
+
+class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
+ __gtype_name__ = 'CanvasIcon'
+
+ __gproperties__ = {
+ 'icon-name': (str, None, None, None,
+ gobject.PARAM_READWRITE),
+ 'color' : (object, None, None,
+ gobject.PARAM_READWRITE),
+ 'size' : (int, None, None,
+ 0, 1024, 24,
+ gobject.PARAM_READWRITE)
+ }
+
+ _cache = _IconCache()
+
+ def __init__(self, **kwargs):
+ self._size = 24
+ self._color = None
+ self._icon_name = None
+
+ hippo.CanvasBox.__init__(self, **kwargs)
+
+ self._buffer = None
+ self._buffer_size = 0.0
+
+ def do_set_property(self, pspec, value):
+ if pspec.name == 'icon-name':
+ self._icon_name = value
+ self.emit_paint_needed(0, 0, -1, -1)
+ elif pspec.name == 'color':
+ self._color = value
+ self.emit_paint_needed(0, 0, -1, -1)
+ elif pspec.name == 'size':
+ self._size = value
+ self.emit_request_changed()
+
+ def do_get_property(self, pspec):
+ if pspec.name == 'size':
+ return self._size
+ elif pspec.name == 'icon-name':
+ return self._icon_name
+ elif pspec.name == 'color':
+ return self._color
+
+ def _get_buffer(self, cr, handle, size):
+ if self._buffer and self._buffer_size != size:
+ del self._buffer
+ self._buffer = None
+
+ if self._buffer == None:
+ target = cr.get_target()
+ surface = target.create_similar(cairo.CONTENT_COLOR_ALPHA,
+ int(size) + 1, int(size) + 1)
+
+ dimensions = handle.get_dimension_data()
+ scale = float(size) / float(dimensions[0])
+
+ ctx = cairo.Context(surface)
+ ctx.scale(scale, scale)
+ handle.render_cairo(ctx)
+ del ctx
+
+ self._buffer = surface
+ self._buffer_scale = scale
+
+ return self._buffer
+
+ def do_paint_below_children(self, cr, damaged_box):
+ icon_name = self._icon_name
+ if icon_name == None:
+ icon_name = 'stock-missing'
+
+ handle = CanvasIcon._cache.get_handle(
+ icon_name, self._color, self._size)
+ buf = self._get_buffer(cr, handle, self._size)
+
+ cr.set_source_surface(buf, 0.0, 0.0)
+ cr.paint()
+
+ def do_get_width_request(self):
+ return self._size
+
+ def do_get_height_request(self, for_width):
+ return self._size
diff --git a/sugar/graphics/grid.py b/sugar/graphics/grid.py
new file mode 100644
index 0000000..be44f43
--- /dev/null
+++ b/sugar/graphics/grid.py
@@ -0,0 +1,15 @@
+import gtk
+
+COLS = 16
+ROWS = 12
+
+class Grid(object):
+ def __init__(self):
+ self._factor = gtk.gdk.screen_width() / COLS
+
+ def position(self, x, y):
+ return [x * self._factor, y * self._factor]
+
+ def rectangle(self, x, y, width, height):
+ return [x * self._factor, y * self._factor,
+ width * self._factor, height * self._factor]
diff --git a/sugar/graphics/style.py b/sugar/graphics/style.py
new file mode 100644
index 0000000..f8a0898
--- /dev/null
+++ b/sugar/graphics/style.py
@@ -0,0 +1,13 @@
+_styles = {}
+
+def register_style(name, style):
+ _styles[name] = style
+
+def apply_style(name, item):
+ if _styles.has_key(name):
+ for name in _styles.keys():
+ item.set_property(name, _styles[name]
+
+def Style(dict):
+ def set_property(self, name, value):
+ self._properties[name] = value