New ProgressIcon widget - SL #4384
A new icon widget useful to display progress. It is compatible with sugar3.graphics.icon.Icon . The progress is represented filling the icon. Signed-off-by: Manuel Quiñones <manuq@laptop.org> Acked-by: Simon Schampijer <simon@laptop.org>
This commit is contained in:
		
							parent
							
								
									3596e8c6cb
								
							
						
					
					
						commit
						693eaab975
					
				@ -6,6 +6,7 @@ sugar_PYTHON =              \
 | 
				
			|||||||
	combobox.py             \
 | 
						combobox.py             \
 | 
				
			||||||
	iconentry.py            \
 | 
						iconentry.py            \
 | 
				
			||||||
	icon.py                 \
 | 
						icon.py                 \
 | 
				
			||||||
 | 
						progressicon.py         \
 | 
				
			||||||
	__init__.py             \
 | 
						__init__.py             \
 | 
				
			||||||
	menuitem.py             \
 | 
						menuitem.py             \
 | 
				
			||||||
	notebook.py             \
 | 
						notebook.py             \
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										101
									
								
								src/sugar3/graphics/progressicon.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								src/sugar3/graphics/progressicon.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,101 @@
 | 
				
			|||||||
 | 
					# 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=None):
 | 
				
			||||||
 | 
					        Gtk.DrawingArea.__init__(self)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self._icon_name = icon_name
 | 
				
			||||||
 | 
					        if direction == None:
 | 
				
			||||||
 | 
					            direction = 'vertical'
 | 
				
			||||||
 | 
					        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()
 | 
				
			||||||
							
								
								
									
										66
									
								
								tests/graphics/progressicon.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								tests/graphics/progressicon.py
									
									
									
									
									
										Normal file
									
								
							@ -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)
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user