Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/sugar/chat/sketchpad
diff options
context:
space:
mode:
authorMarco Pesenti Gritti <mpg@redhat.com>2006-05-20 22:50:39 (GMT)
committer Marco Pesenti Gritti <mpg@redhat.com>2006-05-20 22:50:39 (GMT)
commit41ec035dc7f8bf9ac52f9810c6bc1b25f2dde1b0 (patch)
tree2fae1a29e27900f29e8f967dbcf9bb2e98dcbe30 /sugar/chat/sketchpad
parentdc276e7b7f7eb74d6b5b6e271dd932b559d87812 (diff)
First go at drawing UI
Diffstat (limited to 'sugar/chat/sketchpad')
-rw-r--r--sugar/chat/sketchpad/SketchPad.py7
-rw-r--r--sugar/chat/sketchpad/Toolbox.py66
2 files changed, 65 insertions, 8 deletions
diff --git a/sugar/chat/sketchpad/SketchPad.py b/sugar/chat/sketchpad/SketchPad.py
index d368ff8..b937cea 100644
--- a/sugar/chat/sketchpad/SketchPad.py
+++ b/sugar/chat/sketchpad/SketchPad.py
@@ -26,6 +26,13 @@ class SketchPad(gtk.DrawingArea):
rect = self.get_allocation()
ctx = widget.window.cairo_create()
+ ctx.set_source_rgb(0.6, 1, 0.4)
+ ctx.rectangle(0, 0, rect.width, rect.height)
+ ctx.fill_preserve()
+
+ ctx.set_source_rgb(0, 0.3, 0.2)
+ ctx.stroke()
+
for sketch in self._sketches:
sketch.draw(ctx)
diff --git a/sugar/chat/sketchpad/Toolbox.py b/sugar/chat/sketchpad/Toolbox.py
index d49e863..bf56ccc 100644
--- a/sugar/chat/sketchpad/Toolbox.py
+++ b/sugar/chat/sketchpad/Toolbox.py
@@ -3,6 +3,31 @@ pygtk.require('2.0')
import gtk
import gobject
+class ColorButton(gtk.RadioButton):
+ def __init__(self, group, rgb):
+ gtk.RadioButton.__init__(self, group)
+
+ self._rgb = rgb
+
+ self.set_mode(False)
+ self.set_relief(gtk.RELIEF_NONE)
+
+ drawing_area = gtk.DrawingArea()
+ drawing_area.set_size_request(16, 16)
+ drawing_area.connect('expose_event', self.expose)
+ self.add(drawing_area)
+ drawing_area.show()
+
+ def expose(self, widget, event):
+ rect = widget.get_allocation()
+ ctx = widget.window.cairo_create()
+
+ ctx.set_source_rgb(self._rgb[0], self._rgb[1] , self._rgb[2])
+ ctx.rectangle(0, 0, rect.width, rect.height)
+ ctx.fill()
+
+ return False
+
class Toolbox(gtk.VBox):
__gsignals__ = {
'tool-selected': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
@@ -10,17 +35,28 @@ class Toolbox(gtk.VBox):
}
def __init__(self):
- gtk.VBox.__init__(self)
+ gtk.VBox.__init__(self, False, 12)
- self._tool_hbox = gtk.HBox()
+ self._tools_group = None
+ self._colors_group = None
- self._add_tool('FreeHand', 'freehand')
- self._add_tool('Text', 'text')
+ self._tool_hbox = gtk.HBox(False, 2)
+
+ spring = gtk.Label()
+ self._tool_hbox.pack_start(spring, True)
+ spring.show()
+
+ self._add_tool('stock_draw-text', 'text')
+ self._add_tool('stock_draw-freeform-line', 'freehand')
+
+ spring = gtk.Label()
+ self._tool_hbox.pack_start(spring, True)
+ spring.show()
self.pack_start(self._tool_hbox)
self._tool_hbox.show()
- self._color_hbox = gtk.HBox()
+ self._color_hbox = gtk.HBox(False, 2)
self._add_color([0, 0, 0])
self._add_color([1, 0, 0])
@@ -30,16 +66,30 @@ class Toolbox(gtk.VBox):
self.pack_start(self._color_hbox)
self._color_hbox.show()
- def _add_tool(self, label, tool_id):
- tool = gtk.Button(label)
+ def _add_tool(self, icon, tool_id):
+ image = gtk.Image()
+ image.set_from_icon_name(icon, gtk.ICON_SIZE_LARGE_TOOLBAR)
+
+ tool = gtk.RadioButton(self._tools_group)
+ tool.set_mode(False)
+ tool.set_relief(gtk.RELIEF_NONE)
+ tool.set_image(image)
tool.connect('clicked', self.__tool_clicked_cb, tool_id)
self._tool_hbox.pack_start(tool, False)
+
+ if self._tools_group == None:
+ self._tools_group = tool
+
tool.show()
def _add_color(self, rgb):
- color = gtk.Button('Color')
+ color = ColorButton(self._colors_group, rgb)
color.connect('clicked', self.__color_clicked_cb, rgb)
self._color_hbox.pack_start(color, False)
+
+ if self._colors_group == None:
+ self._colors_group = color
+
color.show()
def __tool_clicked_cb(self, button, tool_id):