Refactor Frame, create RoundBox, some Entry fixes and new Label control.
This commit is contained in:
		
							parent
							
								
									5aa820d72f
								
							
						
					
					
						commit
						f4a6eb4453
					
				@ -10,9 +10,11 @@ sugar_PYTHON =			\
 | 
				
			|||||||
	frame.py		\
 | 
						frame.py		\
 | 
				
			||||||
	grid.py			\
 | 
						grid.py			\
 | 
				
			||||||
	iconcolor.py		\
 | 
						iconcolor.py		\
 | 
				
			||||||
 | 
						label.py		\
 | 
				
			||||||
	menu.py			\
 | 
						menu.py			\
 | 
				
			||||||
	menuicon.py		\
 | 
						menuicon.py		\
 | 
				
			||||||
	menushell.py		\
 | 
						menushell.py		\
 | 
				
			||||||
 | 
					        roundbox.py		\
 | 
				
			||||||
	snowflakebox.py		\
 | 
						snowflakebox.py		\
 | 
				
			||||||
	spreadbox.py		\
 | 
						spreadbox.py		\
 | 
				
			||||||
	style.py		\
 | 
						style.py		\
 | 
				
			||||||
 | 
				
			|||||||
@ -1,41 +1,55 @@
 | 
				
			|||||||
 | 
					# Copyright (C) 2007, 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.
 | 
				
			||||||
import gobject
 | 
					import gobject
 | 
				
			||||||
import hippo
 | 
					import hippo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
from canvasicon import CanvasIcon
 | 
					from canvasicon import CanvasIcon
 | 
				
			||||||
from iconcolor import IconColor
 | 
					from iconcolor import IconColor
 | 
				
			||||||
from grid import Grid
 | 
					 | 
				
			||||||
from sugar import profile
 | 
					from sugar import profile
 | 
				
			||||||
            
 | 
					            
 | 
				
			||||||
class Button(hippo.CanvasBox):
 | 
					class Button(hippo.CanvasBox):
 | 
				
			||||||
    __gtype_name__ = 'Button'
 | 
					    __gtype_name__ = 'Button'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    __gproperties__ = {
 | 
					    __gproperties__ = {
 | 
				
			||||||
        'icon-name': (str, None, None, None,
 | 
					        'icon-name' : (str, None, None, None, gobject.PARAM_READWRITE),
 | 
				
			||||||
                      gobject.PARAM_READWRITE),
 | 
					        'scale'     : (float, None, None, 0.0, 1024.0, 1.0,
 | 
				
			||||||
        'active': (bool, None, None, True,
 | 
					                       gobject.PARAM_READWRITE),
 | 
				
			||||||
                      gobject.PARAM_READWRITE)
 | 
					        'active'    : (bool, None, None, True, gobject.PARAM_READWRITE)
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def __init__(self, icon_name):
 | 
					    def __init__(self, icon_name):
 | 
				
			||||||
        hippo.CanvasBox.__init__(self)
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
        self._active = True
 | 
					 | 
				
			||||||
        self._normal_color = IconColor('white')
 | 
					        self._normal_color = IconColor('white')
 | 
				
			||||||
        self._prelight_color = profile.get_color()
 | 
					        self._prelight_color = profile.get_color()
 | 
				
			||||||
        self._inactive_color = IconColor('#808080,#424242')
 | 
					        self._inactive_color = IconColor('#808080,#424242')
 | 
				
			||||||
                       
 | 
					        self._active = True
 | 
				
			||||||
        grid = Grid()
 | 
					 | 
				
			||||||
        self.props.box_width = grid.dimension(1)
 | 
					 | 
				
			||||||
        self.props.box_height = grid.dimension(1)
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self._icon = CanvasIcon(icon_name=icon_name, cache=True,
 | 
					        self._icon = CanvasIcon(icon_name=icon_name, cache=True,
 | 
				
			||||||
                                color=self._normal_color)
 | 
					                                color=self._normal_color)
 | 
				
			||||||
        self.append(self._icon, hippo.PACK_EXPAND)
 | 
					 | 
				
			||||||
        self._connect_signals(self._icon)
 | 
					        self._connect_signals(self._icon)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        hippo.CanvasBox.__init__(self)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self.append(self._icon, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def do_set_property(self, pspec, value):
 | 
					    def do_set_property(self, pspec, value):
 | 
				
			||||||
        if pspec.name == 'icon-name':
 | 
					        if pspec.name == 'icon-name':
 | 
				
			||||||
            self._icon.props.icon_name = value
 | 
					            self._icon.props.icon_name = value
 | 
				
			||||||
 | 
					        elif pspec.name == 'scale':
 | 
				
			||||||
 | 
					            self._icon.props.scale = value
 | 
				
			||||||
        elif pspec.name == 'active':
 | 
					        elif pspec.name == 'active':
 | 
				
			||||||
            self._active = value
 | 
					            self._active = value
 | 
				
			||||||
            if self._active:
 | 
					            if self._active:
 | 
				
			||||||
@ -47,7 +61,9 @@ class Button(hippo.CanvasBox):
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    def do_get_property(self, pspec):
 | 
					    def do_get_property(self, pspec):
 | 
				
			||||||
        if pspec.name == 'icon-name':
 | 
					        if pspec.name == 'icon-name':
 | 
				
			||||||
            return self._icon.get_property('icon-name')
 | 
					            return self._icon.props.icon_name
 | 
				
			||||||
 | 
					        elif pspec.name == 'scale':
 | 
				
			||||||
 | 
					            return self._icon.props.scale
 | 
				
			||||||
        elif pspec.name == 'active':
 | 
					        elif pspec.name == 'active':
 | 
				
			||||||
            return self._active
 | 
					            return self._active
 | 
				
			||||||
        else:
 | 
					        else:
 | 
				
			||||||
 | 
				
			|||||||
@ -9,7 +9,8 @@ _system_colors = {
 | 
				
			|||||||
    'entry-selection-unfocused'     : '#00FF00',
 | 
					    'entry-selection-unfocused'     : '#00FF00',
 | 
				
			||||||
    'entry-text-focused'            : '#000000',
 | 
					    'entry-text-focused'            : '#000000',
 | 
				
			||||||
    'entry-text-unfocused'          : '#FFFFFF',
 | 
					    'entry-text-unfocused'          : '#FFFFFF',
 | 
				
			||||||
    'entry-border'                  : '#D1D1D2'
 | 
					    'entry-border'                  : '#D1D1D2',
 | 
				
			||||||
 | 
					    'label-text'                    : '#FFFFFF'
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def _html_to_rgb(html_color):
 | 
					def _html_to_rgb(html_color):
 | 
				
			||||||
@ -70,3 +71,4 @@ class Color(object):
 | 
				
			|||||||
    ENTRY_TEXT_FOCUSED          = SystemColor('entry-text-focused')
 | 
					    ENTRY_TEXT_FOCUSED          = SystemColor('entry-text-focused')
 | 
				
			||||||
    ENTRY_TEXT_UNFOCUSED        = SystemColor('entry-text-unfocused')
 | 
					    ENTRY_TEXT_UNFOCUSED        = SystemColor('entry-text-unfocused')
 | 
				
			||||||
    ENTRY_BORDER                = SystemColor('entry-border')
 | 
					    ENTRY_BORDER                = SystemColor('entry-border')
 | 
				
			||||||
 | 
					    LABEL_TEXT                  = SystemColor('label-text')
 | 
				
			||||||
 | 
				
			|||||||
@ -20,9 +20,12 @@ import logging
 | 
				
			|||||||
import gobject
 | 
					import gobject
 | 
				
			||||||
import gtk
 | 
					import gtk
 | 
				
			||||||
import hippo
 | 
					import hippo
 | 
				
			||||||
 | 
					import pango
 | 
				
			||||||
 | 
					
 | 
				
			||||||
from sugar.graphics.frame import Frame
 | 
					from sugar.graphics import style
 | 
				
			||||||
from sugar.graphics.color import Color
 | 
					from sugar.graphics.color import Color
 | 
				
			||||||
 | 
					from sugar.graphics.button import Button
 | 
				
			||||||
 | 
					from sugar.graphics.roundbox import RoundBox
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
					class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			||||||
    __gtype_name__ = 'SugarEntry'
 | 
					    __gtype_name__ = 'SugarEntry'
 | 
				
			||||||
@ -32,12 +35,19 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			|||||||
                      gobject.PARAM_READWRITE)
 | 
					                      gobject.PARAM_READWRITE)
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    _BORDER_WIDTH = 3
 | 
					    __gsignals__ = {
 | 
				
			||||||
 | 
					        'button-activated': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE, ([int]))
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    
 | 
					    
 | 
				
			||||||
    def __init__(self):
 | 
					    def __init__(self):
 | 
				
			||||||
        hippo.CanvasBox.__init__(self)
 | 
					        hippo.CanvasBox.__init__(self, orientation=hippo.ORIENTATION_HORIZONTAL)
 | 
				
			||||||
 | 
					        self.props.yalign = hippo.ALIGNMENT_CENTER
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self._radius = -1
 | 
					        self._buttons = {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self._round_box = RoundBox()
 | 
				
			||||||
 | 
					        self._round_box.props.border_color = Color.FRAME_BORDER.get_int()
 | 
				
			||||||
 | 
					        self.append(self._round_box, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        self._entry = gtk.Entry()
 | 
					        self._entry = gtk.Entry()
 | 
				
			||||||
        self._entry.props.has_frame = False
 | 
					        self._entry.props.has_frame = False
 | 
				
			||||||
@ -46,10 +56,27 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			|||||||
                                Color.BLACK.get_gdk_color())
 | 
					                                Color.BLACK.get_gdk_color())
 | 
				
			||||||
        self._entry.connect('focus-in-event', self._entry_focus_in_event_cb)
 | 
					        self._entry.connect('focus-in-event', self._entry_focus_in_event_cb)
 | 
				
			||||||
        self._entry.connect('focus-out-event', self._entry_focus_out_event_cb)
 | 
					        self._entry.connect('focus-out-event', self._entry_focus_out_event_cb)
 | 
				
			||||||
 | 
					        self._entry.connect('activate', self._entry_activate_cb)
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        fd = pango.FontDescription()
 | 
				
			||||||
 | 
					        fd.set_size(int(round(style.default_font_size * pango.SCALE)))
 | 
				
			||||||
 | 
					        self._entry.modify_font(fd)
 | 
				
			||||||
                
 | 
					                
 | 
				
			||||||
        self._canvas_widget = hippo.CanvasWidget()
 | 
					        self._canvas_widget = hippo.CanvasWidget()
 | 
				
			||||||
        self._canvas_widget.props.widget = self._entry
 | 
					        self._canvas_widget.props.widget = self._entry
 | 
				
			||||||
        self.append(self._canvas_widget, hippo.PACK_EXPAND)
 | 
					        self._round_box.append(self._canvas_widget, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def add_button(self, icon_name, action_id):
 | 
				
			||||||
 | 
					        button = Button(icon_name=icon_name)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        button.props.scale = style.small_icon_scale
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        button.props.yalign = hippo.ALIGNMENT_CENTER
 | 
				
			||||||
 | 
					        button.props.xalign = hippo.ALIGNMENT_START
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        button.connect('activated', self._button_activated_cb)
 | 
				
			||||||
 | 
					        self._round_box.append(button)
 | 
				
			||||||
 | 
					        self._buttons[button] = action_id
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def do_set_property(self, pspec, value):
 | 
					    def do_set_property(self, pspec, value):
 | 
				
			||||||
        if pspec.name == 'text':
 | 
					        if pspec.name == 'text':
 | 
				
			||||||
@ -59,42 +86,6 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			|||||||
        if pspec.name == 'text':
 | 
					        if pspec.name == 'text':
 | 
				
			||||||
            return self._entry.get_text()
 | 
					            return self._entry.get_text()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def do_paint_below_children(self, cr, damaged_box):
 | 
					 | 
				
			||||||
        [width, height] = self._canvas_widget.get_allocation()
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
        x = self.props.padding_left
 | 
					 | 
				
			||||||
        y = self.props.padding_top - self._BORDER_WIDTH / 2
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        cr.move_to(x, y - self._BORDER_WIDTH / 2);
 | 
					 | 
				
			||||||
        cr.arc(x + width + self._BORDER_WIDTH / 2, y - self._BORDER_WIDTH / 2 + self._radius,
 | 
					 | 
				
			||||||
               self._radius, math.pi * 1.5, math.pi * 0.5)
 | 
					 | 
				
			||||||
        cr.arc(x, y + self._radius - self._BORDER_WIDTH / 2, self._radius,
 | 
					 | 
				
			||||||
               math.pi * 0.5, math.pi * 1.5)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        cr.set_source_rgba(*self._background_color.get_rgba())
 | 
					 | 
				
			||||||
        cr.fill_preserve();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        cr.set_line_width(self._BORDER_WIDTH)        
 | 
					 | 
				
			||||||
        cr.set_source_rgba(*Color.ENTRY_BORDER.get_rgba())
 | 
					 | 
				
			||||||
        cr.stroke()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    def do_allocate(self, width, height, origin_changed):
 | 
					 | 
				
			||||||
        hippo.CanvasBox.do_allocate(self, width, height, origin_changed)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        [w_width, w_height] = self._canvas_widget.get_request()
 | 
					 | 
				
			||||||
        radius = min(w_width, w_height) / 2 + self._BORDER_WIDTH
 | 
					 | 
				
			||||||
        if radius != self._radius:
 | 
					 | 
				
			||||||
            self._radius = radius
 | 
					 | 
				
			||||||
            self.props.padding_top = height / 2 - w_height / 2 - self._BORDER_WIDTH / 2
 | 
					 | 
				
			||||||
            self.props.padding_left = self._radius + self._BORDER_WIDTH / 2
 | 
					 | 
				
			||||||
            self.props.padding_right = self._radius + self._BORDER_WIDTH / 2
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
        # Make the entry expand horizontally
 | 
					 | 
				
			||||||
        w_width = width - (self.props.padding_left + self.props.padding_right)
 | 
					 | 
				
			||||||
        
 | 
					 | 
				
			||||||
        self._canvas_widget.do_allocate(self._canvas_widget, w_width, w_height,
 | 
					 | 
				
			||||||
                                        origin_changed)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    def _entry_focus_in_event_cb(self, widget, event):
 | 
					    def _entry_focus_in_event_cb(self, widget, event):
 | 
				
			||||||
        self._update_colors(focused=True)
 | 
					        self._update_colors(focused=True)
 | 
				
			||||||
        self.emit_paint_needed(0, 0, -1, -1)
 | 
					        self.emit_paint_needed(0, 0, -1, -1)
 | 
				
			||||||
@ -103,9 +94,16 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			|||||||
        self._update_colors(focused=False)
 | 
					        self._update_colors(focused=False)
 | 
				
			||||||
        self.emit_paint_needed(0, 0, -1, -1)
 | 
					        self.emit_paint_needed(0, 0, -1, -1)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def _entry_activate_cb(self, entry):
 | 
				
			||||||
 | 
					        self.emit_activated()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def _button_activated_cb(self, button):
 | 
				
			||||||
 | 
					        self.emit('button-activated', self._buttons[button])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def _update_colors(self, focused):
 | 
					    def _update_colors(self, focused):
 | 
				
			||||||
        if focused:
 | 
					        if focused:
 | 
				
			||||||
            self._background_color = Color.ENTRY_BACKGROUND_FOCUSED
 | 
					            self._round_box.props.background_color = \
 | 
				
			||||||
 | 
					                    Color.ENTRY_BACKGROUND_FOCUSED.get_int()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            self._entry.modify_base(gtk.STATE_NORMAL,
 | 
					            self._entry.modify_base(gtk.STATE_NORMAL,
 | 
				
			||||||
                                    Color.ENTRY_BACKGROUND_FOCUSED.get_gdk_color())
 | 
					                                    Color.ENTRY_BACKGROUND_FOCUSED.get_gdk_color())
 | 
				
			||||||
@ -114,7 +112,8 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			|||||||
            self._entry.modify_text(gtk.STATE_NORMAL,
 | 
					            self._entry.modify_text(gtk.STATE_NORMAL,
 | 
				
			||||||
                                    Color.ENTRY_TEXT_FOCUSED.get_gdk_color())
 | 
					                                    Color.ENTRY_TEXT_FOCUSED.get_gdk_color())
 | 
				
			||||||
        else:
 | 
					        else:
 | 
				
			||||||
            self._background_color = Color.ENTRY_BACKGROUND_UNFOCUSED
 | 
					            self._round_box.props.background_color = \
 | 
				
			||||||
 | 
					                    Color.ENTRY_BACKGROUND_UNFOCUSED.get_int()
 | 
				
			||||||
        
 | 
					        
 | 
				
			||||||
            self._entry.modify_base(gtk.STATE_NORMAL,
 | 
					            self._entry.modify_base(gtk.STATE_NORMAL,
 | 
				
			||||||
                                    Color.ENTRY_BACKGROUND_UNFOCUSED.get_gdk_color())
 | 
					                                    Color.ENTRY_BACKGROUND_UNFOCUSED.get_gdk_color())
 | 
				
			||||||
 | 
				
			|||||||
@ -15,40 +15,12 @@
 | 
				
			|||||||
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 | 
					# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 | 
				
			||||||
# Boston, MA 02111-1307, USA.
 | 
					# Boston, MA 02111-1307, USA.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import math
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
import hippo
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
from sugar.graphics.color import Color
 | 
					from sugar.graphics.color import Color
 | 
				
			||||||
 | 
					from sugar.graphics.roundbox import RoundBox
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class Frame(hippo.CanvasBox, hippo.CanvasItem):
 | 
					class Frame(RoundBox):
 | 
				
			||||||
    __gtype_name__ = 'SugarFrame'
 | 
					    __gtype_name__ = 'SugarFrame'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    def __init__(self, **kwargs):
 | 
					    def __init__(self, **kwargs):
 | 
				
			||||||
        hippo.CanvasBox.__init__(self, **kwargs)
 | 
					        RoundBox.__init__(self, **kwargs)
 | 
				
			||||||
 | 
					        self.props.border_color = Color.FRAME_BORDER.get_int()
 | 
				
			||||||
        self._line_width = 3.0
 | 
					 | 
				
			||||||
        self._radius = 30
 | 
					 | 
				
			||||||
        self._border_color = Color.FRAME_BORDER
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    def do_paint_below_children(self, cr, damaged_box):
 | 
					 | 
				
			||||||
        [width, height] = self.get_allocation()
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        x = self._line_width
 | 
					 | 
				
			||||||
        y = self._line_width
 | 
					 | 
				
			||||||
        width -= self._line_width * 2
 | 
					 | 
				
			||||||
        height -= self._line_width * 2
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        cr.move_to(x + self._radius, y);
 | 
					 | 
				
			||||||
        cr.arc(x + width - self._radius, y + self._radius,
 | 
					 | 
				
			||||||
               self._radius, math.pi * 1.5, math.pi * 2);
 | 
					 | 
				
			||||||
        cr.arc(x + width - self._radius, x + height - self._radius,
 | 
					 | 
				
			||||||
               self._radius, 0, math.pi * 0.5);
 | 
					 | 
				
			||||||
        cr.arc(x + self._radius, y + height - self._radius,
 | 
					 | 
				
			||||||
               self._radius, math.pi * 0.5, math.pi);
 | 
					 | 
				
			||||||
        cr.arc(x + self._radius, y + self._radius, self._radius,
 | 
					 | 
				
			||||||
               math.pi, math.pi * 1.5);
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        cr.set_source_rgba(*self._border_color.get_rgba())
 | 
					 | 
				
			||||||
        cr.set_line_width(self._line_width)
 | 
					 | 
				
			||||||
        cr.stroke()
 | 
					 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										76
									
								
								sugar/graphics/label.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								sugar/graphics/label.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,76 @@
 | 
				
			|||||||
 | 
					# Copyright (C) 2007, 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.
 | 
				
			||||||
 | 
					import math
 | 
				
			||||||
 | 
					import logging
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import gobject
 | 
				
			||||||
 | 
					import gtk
 | 
				
			||||||
 | 
					import hippo
 | 
				
			||||||
 | 
					import pango
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from sugar.graphics import style
 | 
				
			||||||
 | 
					from sugar.graphics.roundbox import RoundBox
 | 
				
			||||||
 | 
					from sugar.graphics.button import Button
 | 
				
			||||||
 | 
					from sugar.graphics.color import Color
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class Label(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			||||||
 | 
					    __gtype_name__ = 'SugarLabel'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    __gproperties__ = {
 | 
				
			||||||
 | 
					        'text'    : (str, None, None, None,
 | 
				
			||||||
 | 
					                      gobject.PARAM_READWRITE)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    __gsignals__ = {
 | 
				
			||||||
 | 
					        'button-activated': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE, ([int]))
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					    def __init__(self, text):
 | 
				
			||||||
 | 
					        hippo.CanvasBox.__init__(self, orientation=hippo.ORIENTATION_HORIZONTAL)
 | 
				
			||||||
 | 
					        self.props.yalign = hippo.ALIGNMENT_CENTER
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self._buttons = {}
 | 
				
			||||||
 | 
					        self._text = text
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self._round_box = RoundBox()
 | 
				
			||||||
 | 
					        self._round_box.props.border_color = Color.FRAME_BORDER.get_int()
 | 
				
			||||||
 | 
					        self.append(self._round_box, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self._canvas_text = hippo.CanvasText()
 | 
				
			||||||
 | 
					        self._canvas_text.props.text = self._text
 | 
				
			||||||
 | 
					        self._canvas_text.props.color = Color.LABEL_TEXT.get_int()
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        fd = pango.FontDescription()
 | 
				
			||||||
 | 
					        fd.set_size(int(round(style.default_font_size * pango.SCALE)))        
 | 
				
			||||||
 | 
					        self._canvas_text.props.font_desc = fd
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        self._round_box.append(self._canvas_text, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def add_button(self, icon_name, action_id):
 | 
				
			||||||
 | 
					        button = Button(icon_name=icon_name)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        button.props.scale = style.small_icon_scale
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        button.props.yalign = hippo.ALIGNMENT_CENTER
 | 
				
			||||||
 | 
					        button.props.xalign = hippo.ALIGNMENT_START
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        button.connect('activated', self._button_activated_cb)
 | 
				
			||||||
 | 
					        self._round_box.append(button)
 | 
				
			||||||
 | 
					        self._buttons[button] = action_id
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def _button_activated_cb(self, button):
 | 
				
			||||||
 | 
					        self.emit('button-activated', self._buttons[button])
 | 
				
			||||||
							
								
								
									
										66
									
								
								sugar/graphics/roundbox.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								sugar/graphics/roundbox.py
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,66 @@
 | 
				
			|||||||
 | 
					# Copyright (C) 2006, Red Hat, Inc.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 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.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import math
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import hippo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from sugar.graphics import style
 | 
				
			||||||
 | 
					from sugar.graphics.color import Color
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class RoundBox(hippo.CanvasBox, hippo.CanvasItem):
 | 
				
			||||||
 | 
					    __gtype_name__ = 'SugarRoundBox'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    _BORDER_DEFAULT = 2.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    def __init__(self, **kwargs):
 | 
				
			||||||
 | 
					        hippo.CanvasBox.__init__(self, **kwargs)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # TODO: we should calculate this value depending on the height of the box.
 | 
				
			||||||
 | 
					        self._radius = 10 * style.screen_factor
 | 
				
			||||||
 | 
					        
 | 
				
			||||||
 | 
					        self.props.orientation = hippo.ORIENTATION_HORIZONTAL
 | 
				
			||||||
 | 
					        self.props.border_top = self._BORDER_DEFAULT
 | 
				
			||||||
 | 
					        self.props.border_bottom = self._BORDER_DEFAULT
 | 
				
			||||||
 | 
					        self.props.border_left = self._radius
 | 
				
			||||||
 | 
					        self.props.border_right = self._radius
 | 
				
			||||||
 | 
					        self.props.border_color = Color.BLACK.get_int()
 | 
				
			||||||
 | 
					            
 | 
				
			||||||
 | 
					    def do_paint_background(self, cr, damaged_box):
 | 
				
			||||||
 | 
					        [width, height] = self.get_allocation()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        x = self._BORDER_DEFAULT / 2
 | 
				
			||||||
 | 
					        y = self._BORDER_DEFAULT / 2
 | 
				
			||||||
 | 
					        width -= self._BORDER_DEFAULT
 | 
				
			||||||
 | 
					        height -= self._BORDER_DEFAULT
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        cr.move_to(x + self._radius, y);
 | 
				
			||||||
 | 
					        cr.arc(x + width - self._radius, y + self._radius,
 | 
				
			||||||
 | 
					               self._radius, math.pi * 1.5, math.pi * 2);
 | 
				
			||||||
 | 
					        cr.arc(x + width - self._radius, x + height - self._radius,
 | 
				
			||||||
 | 
					               self._radius, 0, math.pi * 0.5);
 | 
				
			||||||
 | 
					        cr.arc(x + self._radius, y + height - self._radius,
 | 
				
			||||||
 | 
					               self._radius, math.pi * 0.5, math.pi);
 | 
				
			||||||
 | 
					        cr.arc(x + self._radius, y + self._radius, self._radius,
 | 
				
			||||||
 | 
					               math.pi, math.pi * 1.5);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        hippo.cairo_set_source_rgba32(cr, self.props.background_color)
 | 
				
			||||||
 | 
					        cr.fill_preserve();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        hippo.cairo_set_source_rgba32(cr, self.props.border_color)
 | 
				
			||||||
 | 
					        cr.set_line_width(self._BORDER_DEFAULT)
 | 
				
			||||||
 | 
					        cr.stroke()
 | 
				
			||||||
@ -20,16 +20,18 @@ import gtk
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
_styles = {}
 | 
					_styles = {}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
_screen_factor = gtk.gdk.screen_width() / 1200.0
 | 
					screen_factor = gtk.gdk.screen_width() / 1200.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
space_unit = 9 * _screen_factor
 | 
					space_unit = 9 * screen_factor
 | 
				
			||||||
separator_thickness = 3 * _screen_factor
 | 
					separator_thickness = 3 * screen_factor
 | 
				
			||||||
 | 
					
 | 
				
			||||||
standard_icon_scale = 1.0 * _screen_factor
 | 
					standard_icon_scale = 1.0 * screen_factor
 | 
				
			||||||
small_icon_scale    = 0.5 * _screen_factor
 | 
					small_icon_scale    = 0.5 * screen_factor
 | 
				
			||||||
medium_icon_scale   = 1.5 * _screen_factor
 | 
					medium_icon_scale   = 1.5 * screen_factor
 | 
				
			||||||
large_icon_scale    = 2.0 * _screen_factor
 | 
					large_icon_scale    = 2.0 * screen_factor
 | 
				
			||||||
xlarge_icon_scale   = 3.0 * _screen_factor
 | 
					xlarge_icon_scale   = 3.0 * screen_factor
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					default_font_size   = 9.0 * screen_factor
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def load_stylesheet(module):
 | 
					def load_stylesheet(module):
 | 
				
			||||||
    for objname in dir(module):
 | 
					    for objname in dir(module):
 | 
				
			||||||
@ -50,5 +52,5 @@ def apply_stylesheet(item, stylesheet_name):
 | 
				
			|||||||
        logging.debug('Stylesheet %s not found.' % stylesheet_name)
 | 
					        logging.debug('Stylesheet %s not found.' % stylesheet_name)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def get_font_description(style, relative_size):
 | 
					def get_font_description(style, relative_size):
 | 
				
			||||||
    base_size = 18 * _screen_factor
 | 
					    base_size = 18 * screen_factor
 | 
				
			||||||
    return '%s %dpx' % (style, int(base_size * relative_size))
 | 
					    return '%s %dpx' % (style, int(base_size * relative_size))
 | 
				
			||||||
 | 
				
			|||||||
@ -22,6 +22,14 @@ from sugar.graphics.toolbar import Toolbar
 | 
				
			|||||||
from sugar.graphics.frame import Frame
 | 
					from sugar.graphics.frame import Frame
 | 
				
			||||||
from sugar.graphics.button import Button
 | 
					from sugar.graphics.button import Button
 | 
				
			||||||
from sugar.graphics.entry import Entry
 | 
					from sugar.graphics.entry import Entry
 | 
				
			||||||
 | 
					from sugar.graphics.color import Color
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def _entry_activated_cb(entry):
 | 
				
			||||||
 | 
					    print "_entry_activated_cb"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					def _entry_button_activated_cb(entry, action_id):
 | 
				
			||||||
 | 
					    print "_entry_button_activated_cb: " + str(action_id)
 | 
				
			||||||
 | 
					    entry.props.text = ''
 | 
				
			||||||
 | 
					
 | 
				
			||||||
window = gtk.Window()
 | 
					window = gtk.Window()
 | 
				
			||||||
window.connect("destroy", lambda w: gtk.main_quit())
 | 
					window.connect("destroy", lambda w: gtk.main_quit())
 | 
				
			||||||
@ -34,26 +42,31 @@ canvas.show()
 | 
				
			|||||||
vbox = hippo.CanvasBox()
 | 
					vbox = hippo.CanvasBox()
 | 
				
			||||||
canvas.set_root(vbox)
 | 
					canvas.set_root(vbox)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
toolbar = Toolbar()
 | 
					for i in [1, 2]:
 | 
				
			||||||
vbox.append(toolbar)
 | 
					    toolbar = Toolbar()
 | 
				
			||||||
 | 
					    vbox.append(toolbar)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
button = Button('theme:stock-close')
 | 
					    button = Button('theme:stock-close')
 | 
				
			||||||
toolbar.append(button)
 | 
					    toolbar.append(button)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
entry = Entry()
 | 
					    BUTTON_DELETE = 1
 | 
				
			||||||
entry.props.text = 'mec mac'
 | 
					    entry = Entry()
 | 
				
			||||||
toolbar.append(entry, hippo.PACK_EXPAND)
 | 
					    entry.props.text = 'mec mac'
 | 
				
			||||||
 | 
					    entry.add_button('theme:stock-close', BUTTON_DELETE)
 | 
				
			||||||
 | 
					    entry.connect('activated', _entry_activated_cb)
 | 
				
			||||||
 | 
					    entry.connect('button-activated', _entry_button_activated_cb)
 | 
				
			||||||
 | 
					    toolbar.append(entry, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
entry2 = Entry()
 | 
					    entry = Entry()
 | 
				
			||||||
entry2.props.text = 'moc muc'
 | 
					    entry.props.text = 'moc muc'
 | 
				
			||||||
toolbar.append(entry2, hippo.PACK_EXPAND)
 | 
					    toolbar.append(entry, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
gtk_entry = gtk.Entry()
 | 
					    gtk_entry = gtk.Entry()
 | 
				
			||||||
gtk_entry.props.has_frame = False
 | 
					    gtk_entry.props.has_frame = False
 | 
				
			||||||
#gtk_entry.connect("activate", self._entry_activate_cb)
 | 
					    #gtk_entry.connect("activate", self._entry_activate_cb)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
gtk_entry_widget = hippo.CanvasWidget()
 | 
					    gtk_entry_widget = hippo.CanvasWidget()
 | 
				
			||||||
gtk_entry_widget.props.widget = gtk_entry
 | 
					    gtk_entry_widget.props.widget = gtk_entry
 | 
				
			||||||
toolbar.append(gtk_entry_widget, hippo.PACK_EXPAND)
 | 
					    toolbar.append(gtk_entry_widget, hippo.PACK_EXPAND)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
gtk.main()
 | 
					gtk.main()
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										52
									
								
								tests/test-label.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										52
									
								
								tests/test-label.py
									
									
									
									
									
										Executable file
									
								
							@ -0,0 +1,52 @@
 | 
				
			|||||||
 | 
					#!/usr/bin/env python
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# Copyright (C) 2007, One Laptop Per Child
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This program is free software; you can redistribute it and/or modify
 | 
				
			||||||
 | 
					# it under the terms of the GNU General Public License as published by
 | 
				
			||||||
 | 
					# the Free Software Foundation; either version 2 of the License, or
 | 
				
			||||||
 | 
					# (at your option) any later version.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This program 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 General Public License for more details.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# You should have received a copy of the GNU General Public License
 | 
				
			||||||
 | 
					# along with this program; if not, write to the Free Software
 | 
				
			||||||
 | 
					# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 | 
				
			||||||
 | 
					import gtk
 | 
				
			||||||
 | 
					import hippo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					from sugar.graphics.toolbar import Toolbar
 | 
				
			||||||
 | 
					from sugar.graphics.label import Label
 | 
				
			||||||
 | 
					from sugar.graphics.button import Button
 | 
				
			||||||
 | 
					from sugar.graphics.color import Color
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					BUTTON_DELETE = 1
 | 
				
			||||||
 | 
					    
 | 
				
			||||||
 | 
					window = gtk.Window()
 | 
				
			||||||
 | 
					window.connect("destroy", lambda w: gtk.main_quit())
 | 
				
			||||||
 | 
					window.show()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					canvas = hippo.Canvas()
 | 
				
			||||||
 | 
					window.add(canvas)
 | 
				
			||||||
 | 
					canvas.show()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					vbox = hippo.CanvasBox()
 | 
				
			||||||
 | 
					canvas.set_root(vbox)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					toolbar = Toolbar()
 | 
				
			||||||
 | 
					vbox.append(toolbar)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					button = Button('theme:stock-close')
 | 
				
			||||||
 | 
					toolbar.append(button)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					label = Label('mec moc')
 | 
				
			||||||
 | 
					toolbar.append(label)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					label = Label('mac mic')
 | 
				
			||||||
 | 
					label.add_button('theme:stock-close', BUTTON_DELETE)
 | 
				
			||||||
 | 
					toolbar.append(label)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					gtk.main()
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user