Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSantiago Collazo <scollazo@activitycentral.com>2013-01-18 14:21:45 (GMT)
committer Santiago Collazo <scollazo@activitycentral.com>2013-01-18 14:21:45 (GMT)
commitbef4413649a096a4ed9b9116819d51a34104c8d6 (patch)
tree7c51fe538e32cd88c6d7214007fef135ce514600
parenta443196ef5ad62c33b2551ff067042bb2d6fde88 (diff)
parent8a7069aa79099f914878d4ad5eaf71ea03517555 (diff)
Merge remote-tracking branch 'ajay/0.97.7-as-base' into devel
-rw-r--r--src/sugar3/graphics/Makefile.am1
-rw-r--r--src/sugar3/graphics/iconentry.py2
-rw-r--r--src/sugar3/graphics/palettewindow.py1
-rw-r--r--src/sugar3/graphics/progressicon.py99
-rw-r--r--tests/graphics/common.py3
-rw-r--r--tests/graphics/progressicon.py66
6 files changed, 169 insertions, 3 deletions
diff --git a/src/sugar3/graphics/Makefile.am b/src/sugar3/graphics/Makefile.am
index a4f9629..344cc82 100644
--- a/src/sugar3/graphics/Makefile.am
+++ b/src/sugar3/graphics/Makefile.am
@@ -6,6 +6,7 @@ sugar_PYTHON = \
combobox.py \
iconentry.py \
icon.py \
+ progressicon.py \
__init__.py \
menuitem.py \
notebook.py \
diff --git a/src/sugar3/graphics/iconentry.py b/src/sugar3/graphics/iconentry.py
index f4e5682..243807f 100644
--- a/src/sugar3/graphics/iconentry.py
+++ b/src/sugar3/graphics/iconentry.py
@@ -80,7 +80,7 @@ class IconEntry(Gtk.Entry):
def show_clear_button(self):
if not self._clear_shown:
self.set_icon_from_name(ICON_ENTRY_SECONDARY,
- 'dialog-cancel')
+ 'entry-cancel')
self._clear_shown = True
def hide_clear_button(self):
diff --git a/src/sugar3/graphics/palettewindow.py b/src/sugar3/graphics/palettewindow.py
index ff5e340..c48ae55 100644
--- a/src/sugar3/graphics/palettewindow.py
+++ b/src/sugar3/graphics/palettewindow.py
@@ -148,6 +148,7 @@ class _PaletteMenuWidget(Gtk.Menu):
self._invoker = invoker
self._find_all_menus(self)
+ self.realize()
for menu in self._menus:
if self._invoker:
menu.connect('motion-notify-event', self._motion_notify_cb)
diff --git a/src/sugar3/graphics/progressicon.py b/src/sugar3/graphics/progressicon.py
new file mode 100644
index 0000000..0153ae2
--- /dev/null
+++ b/src/sugar3/graphics/progressicon.py
@@ -0,0 +1,99 @@
+# Copyright (C) 2013, One Laptop Per Child
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the
+# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+
+from gi.repository import Gtk
+from sugar3.graphics.icon import get_surface
+from sugar3.graphics import style
+
+
+class ProgressIcon(Gtk.DrawingArea):
+ """Display the progress filling the icon.
+
+ This class is compatible with the sugar3.graphics.icon.Icon class.
+
+ Call update(progress) with the new progress to update the icon.
+
+ The direction defaults to 'vertical', in which case the icon is
+ filled from bottom to top. If direction is set to 'horizontal',
+ it will be filled from right to left or from left to right,
+ depending on the system's language RTL setting.
+
+ """
+ def __init__(self, icon_name, pixel_size, stroke_color, fill_color,
+ direction='vertical'):
+ Gtk.DrawingArea.__init__(self)
+
+ self._icon_name = icon_name
+ self._direction = direction
+ self._progress = 0
+
+ self._stroke = get_surface(
+ icon_name=icon_name, width=pixel_size, height=pixel_size,
+ stroke_color=stroke_color,
+ fill_color=style.COLOR_TRANSPARENT.get_svg())
+
+ self._fill = get_surface(
+ icon_name=icon_name, width=pixel_size, height=pixel_size,
+ stroke_color=style.COLOR_TRANSPARENT.get_svg(),
+ fill_color=fill_color)
+
+ self.connect("draw", self.__draw_cb)
+
+ def __draw_cb(self, widget, cr):
+ allocation = widget.get_allocation()
+
+ # Center the graphic in the allocated space.
+ margin_x = (allocation.width - self._stroke.get_width()) / 2
+ margin_y = (allocation.height - self._stroke.get_height()) / 2
+ cr.translate(margin_x, margin_y)
+
+ # Paint the fill, clipping it by the progress.
+ x_, y_ = 0, 0
+ width, height = self._stroke.get_width(), self._stroke.get_height()
+ if self._direction == 'vertical': # vertical direction, bottom to top
+ y_ = self._stroke.get_height()
+ height *= self._progress * -1
+ else:
+ rtl_direction = \
+ Gtk.Widget.get_default_direction() == Gtk.TextDirection.RTL
+ if rtl_direction: # horizontal direction, right to left
+ x_ = self._stroke.get_width()
+ width *= self._progress * -1
+ else: # horizontal direction, left to right
+ width *= self._progress
+
+ cr.rectangle(x_, y_, width, height)
+ cr.clip()
+ cr.set_source_surface(self._fill, 0, 0)
+ cr.paint()
+
+ # Paint the stroke over the fill.
+ cr.reset_clip()
+ cr.set_source_surface(self._stroke, 0, 0)
+ cr.paint()
+
+ def do_get_preferred_width(self):
+ width = self._stroke.get_width()
+ return (width, width)
+
+ def do_get_preferred_height(self):
+ height = self._stroke.get_height()
+ return (height, height)
+
+ def update(self, progress):
+ self._progress = progress
+ self.queue_draw()
diff --git a/tests/graphics/common.py b/tests/graphics/common.py
index 02c3e19..8d516ad 100644
--- a/tests/graphics/common.py
+++ b/tests/graphics/common.py
@@ -31,7 +31,7 @@ def set_theme():
sugar_theme = 'sugar-100'
settings.set_property('gtk-theme-name', sugar_theme)
settings.set_property('gtk-icon-theme-name', 'sugar')
-
+set_theme()
class Test(Gtk.VBox):
def __init__(self):
@@ -57,7 +57,6 @@ class TestPalette(Test):
class TestRunner(object):
def run(self, test):
- set_theme()
window = Gtk.Window()
window.connect('destroy', lambda w: Gtk.main_quit())
window.add(test)
diff --git a/tests/graphics/progressicon.py b/tests/graphics/progressicon.py
new file mode 100644
index 0000000..3dbd4b1
--- /dev/null
+++ b/tests/graphics/progressicon.py
@@ -0,0 +1,66 @@
+# Copyright (C) 2013, One Laptop Per Child
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the
+# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+# Boston, MA 02111-1307, USA.
+
+"""
+Test the sugar3.graphics.progressicon.ProgressIcon widget.
+"""
+
+
+from gi.repository import GObject
+
+from sugar3.graphics.progressicon import ProgressIcon
+from sugar3.graphics.icon import Icon, get_surface
+from sugar3.graphics import style
+
+import common
+
+test = common.Test()
+test.show()
+
+icon = ProgressIcon(
+ pixel_size=style.LARGE_ICON_SIZE,
+ icon_name='computer-xo',
+ stroke_color=style.COLOR_BUTTON_GREY.get_svg(),
+ fill_color=style.COLOR_WHITE.get_svg())
+test.pack_start(icon, True, True, 0)
+icon.show()
+
+icon2 = ProgressIcon(
+ pixel_size=style.LARGE_ICON_SIZE,
+ icon_name='computer-xo',
+ stroke_color=style.COLOR_BUTTON_GREY.get_svg(),
+ fill_color=style.COLOR_WHITE.get_svg(),
+ direction='horizontal')
+test.pack_start(icon2, True, True, 0)
+icon2.show()
+
+progress = 0
+
+
+def timeout_cb():
+ global progress
+ progress += 0.05
+ icon.update(progress)
+ icon2.update(progress)
+ if progress >= 1:
+ return False
+ return True
+
+GObject.timeout_add(50, timeout_cb)
+
+if __name__ == '__main__':
+ common.main(test)