Merge branch 'master' of git+ssh://dev.laptop.org/git/sugar

This commit is contained in:
Dan Williams 2007-02-28 15:48:48 -05:00
commit 9333af3d07
7 changed files with 44 additions and 50 deletions

View File

@ -9,5 +9,6 @@ sugar_PYTHON = \
clipboardicon.py \ clipboardicon.py \
clipboardmenu.py \ clipboardmenu.py \
keyhandler.py \ keyhandler.py \
pulsingicon.py \
OverlayWindow.py \ OverlayWindow.py \
Shell.py Shell.py

View File

@ -14,7 +14,7 @@
# License along with this library; if not, write to the # License along with this library; if not, write to the
# 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 logging
import re import re
import gobject import gobject
@ -137,7 +137,7 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
'icon-name' : (str, None, None, None, 'icon-name' : (str, None, None, None,
gobject.PARAM_READWRITE), gobject.PARAM_READWRITE),
'xo-color' : (object, None, None, 'xo-color' : (object, None, None,
gobject.PARAM_READWRITE), gobject.PARAM_WRITABLE),
'fill-color' : (object, None, None, 'fill-color' : (object, None, None,
gobject.PARAM_READWRITE), gobject.PARAM_READWRITE),
'stroke-color' : (object, None, None, 'stroke-color' : (object, None, None,
@ -148,6 +148,8 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
'cache' : (bool, None, None, False, 'cache' : (bool, None, None, False,
gobject.PARAM_READWRITE), gobject.PARAM_READWRITE),
'tooltip' : (str, None, None, None, 'tooltip' : (str, None, None, None,
gobject.PARAM_READWRITE),
'active' : (bool, None, None, True,
gobject.PARAM_READWRITE) gobject.PARAM_READWRITE)
} }
@ -165,6 +167,7 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
self._popup = None self._popup = None
self._hover_popup = False self._hover_popup = False
self._tooltip = False self._tooltip = False
self._active = True
self._timeline = Timeline(self) self._timeline = Timeline(self)
self._timeline.add_tag('popup', 6, 6) self._timeline.add_tag('popup', 6, 6)
@ -216,38 +219,47 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
self._cache = value self._cache = value
elif pspec.name == 'tooltip': elif pspec.name == 'tooltip':
self._tooltip = value self._tooltip = value
elif pspec.name == 'active':
if self._active != value:
if not self._cache:
self._clear_buffers()
self._active = value
self._handle = None
self.emit_paint_needed(0, 0, -1, -1)
def _choose_colors(self):
fill_color = None
stroke_color = None
if self._active:
if self._fill_color:
fill_color = self._fill_color.get_html()
if self._stroke_color:
stroke_color = self._stroke_color.get_html()
else:
stroke_color = color.ICON_STROKE_INACTIVE.get_html()
if self._fill_color:
fill_color = self._fill_color.get_html()
return [fill_color, stroke_color]
def _get_handle(self): def _get_handle(self):
if not self._handle: if not self._handle:
cache = CanvasIcon._cache cache = CanvasIcon._cache
fill_color = None [fill_color, stroke_color] = self._choose_colors()
if self._fill_color:
fill_color = self._fill_color.get_html()
stroke_color = None
if self._stroke_color:
stroke_color = self._stroke_color.get_html()
self._handle = cache.get_handle(self._icon_name, fill_color, self._handle = cache.get_handle(self._icon_name, fill_color,
stroke_color) stroke_color)
return self._handle return self._handle
def _get_current_buffer_key(self): def _get_current_buffer_key(self):
return (self._icon_name, self._fill_color, self._stroke_color, self._scale) [fill_color, stroke_color] = self._choose_colors()
return (self._icon_name, fill_color, stroke_color, self._scale)
def do_get_property(self, pspec): def do_get_property(self, pspec):
if pspec.name == 'scale': if pspec.name == 'scale':
return self._scale return self._scale
elif pspec.name == 'icon-name': elif pspec.name == 'icon-name':
return self._icon_name return self._icon_name
elif pspec.name == 'xo-color':
if self._stroke_color and self._fill_color:
xo_color = XoColor('%s,%s' % (self._stroke_color.get_html(),
self._fill_color.get_html()))
return xo_color
else:
return None
elif pspec.name == 'fill-color': elif pspec.name == 'fill-color':
return self._fill_color return self._fill_color
elif pspec.name == 'stroke-color': elif pspec.name == 'stroke-color':
@ -256,6 +268,8 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem):
return self._cache return self._cache
elif pspec.name == 'tooltip': elif pspec.name == 'tooltip':
return self._tooltip return self._tooltip
elif pspec.name == 'active':
return self._active
def _get_icon_size(self): def _get_icon_size(self):
handle = self._get_handle() handle = self._get_handle()

View File

@ -20,8 +20,6 @@ _system_colors = {
'button-background-normal' : '#424242', 'button-background-normal' : '#424242',
'button-hover' : '#808080', 'button-hover' : '#808080',
'button-background-hover' : '#000000', 'button-background-hover' : '#000000',
'button-inactive' : '#808080',
'button-background-inactive' : '#424242',
'icon-stroke-inactive' : '#757575', 'icon-stroke-inactive' : '#757575',
'icon-fill-inactive' : '#9D9FA1' 'icon-fill-inactive' : '#9D9FA1'
} }
@ -100,7 +98,5 @@ BUTTON_NORMAL = SystemColor('button-normal')
BUTTON_BACKGROUND_NORMAL = SystemColor('button-background-normal') BUTTON_BACKGROUND_NORMAL = SystemColor('button-background-normal')
BUTTON_HOVER = SystemColor('button-hover') BUTTON_HOVER = SystemColor('button-hover')
BUTTON_BACKGROUND_HOVER = SystemColor('button-background-hover') BUTTON_BACKGROUND_HOVER = SystemColor('button-background-hover')
BUTTON_INACTIVE = SystemColor('button-inactive')
BUTTON_BACKGROUND_INACTIVE = SystemColor('button-background-inactive')
ICON_FILL_INACTIVE = SystemColor('icon-fill-inactive') ICON_FILL_INACTIVE = SystemColor('icon-fill-inactive')
ICON_STROKE_INACTIVE = SystemColor('icon-stroke-inactive') ICON_STROKE_INACTIVE = SystemColor('icon-stroke-inactive')

View File

@ -3,8 +3,8 @@ import pango
from sugar.graphics import units from sugar.graphics import units
_system_fonts = { _system_fonts = {
'default' : 'Bitstream Vera Sans %dpx' % units.points_to_pixels(9), 'default' : 'Bitstream Vera Sans %d' % units.points_to_device(9),
'default-bold' : 'Bitstream Vera Sans bold %dpx' % units.points_to_pixels(9) 'default-bold' : 'Bitstream Vera Sans bold %d' % units.points_to_device(9)
} }
class Font(object): class Font(object):

View File

@ -33,26 +33,15 @@ class IconButton(CanvasIcon):
__gproperties__ = { __gproperties__ = {
'size' : (int, None, None, 'size' : (int, None, None,
0, sys.maxint, STANDARD_SIZE, 0, sys.maxint, STANDARD_SIZE,
gobject.PARAM_READWRITE),
'active' : (bool, None, None, True,
gobject.PARAM_READWRITE) gobject.PARAM_READWRITE)
} }
def __init__(self, **kwargs): def __init__(self, **kwargs):
self._active = True
CanvasIcon.__init__(self, cache=True, **kwargs) CanvasIcon.__init__(self, cache=True, **kwargs)
if self._active: if not self.props.fill_color and not self.props.stroke_color:
self.props.fill_color = color.BUTTON_BACKGROUND_NORMAL self.props.fill_color = color.BUTTON_BACKGROUND_NORMAL
self.props.stroke_color = color.BUTTON_NORMAL self.props.stroke_color = color.BUTTON_NORMAL
self.props.background_color = \
color.BUTTON_BACKGROUND_NORMAL.get_int()
else:
self.props.fill_color = color.BUTTON_BACKGROUND_INACTIVE
self.props.stroke_color = color.BUTTON_INACTIVE
self.props.background_color = \
color.BUTTON_BACKGROUND_INACTIVE.get_int()
self._set_size(STANDARD_SIZE) self._set_size(STANDARD_SIZE)
@ -74,22 +63,12 @@ class IconButton(CanvasIcon):
def do_set_property(self, pspec, value): def do_set_property(self, pspec, value):
if pspec.name == 'size': if pspec.name == 'size':
self._set_size(value) self._set_size(value)
elif pspec.name == 'active':
self._active = value
if self._active:
self.props.fill_color = color.BUTTON_BACKGROUND_NORMAL
self.props.stroke_color = color.BUTTON_NORMAL
else:
self.props.fill_color = color.BUTTON_BACKGROUND_INACTIVE
self.props.stroke_color = color.BUTTON_INACTIVE
else: else:
CanvasIcon.do_set_property(self, pspec, value) CanvasIcon.do_set_property(self, pspec, value)
def do_get_property(self, pspec): def do_get_property(self, pspec):
if pspec.name == 'size': if pspec.name == 'size':
return self._size return self._size
elif pspec.name == 'active':
return self._active
else: else:
return CanvasIcon.do_get_property(self, pspec) return CanvasIcon.do_get_property(self, pspec)
@ -100,7 +79,7 @@ class IconButton(CanvasIcon):
def prelight(self, enter): def prelight(self, enter):
if enter: if enter:
if self._active: if self.props.active:
self.props.background_color = color.BLACK.get_int() self.props.background_color = color.BLACK.get_int()
else: else:
self.props.background_color = \ self.props.background_color = \

View File

@ -64,7 +64,7 @@ import gtk
import _sugar import _sugar
_MAX_ZOOM_FACTOR = 1.5 _MAX_ZOOM_FACTOR = 1.5
_ZOOM_CONSTANT = 600.0 _ZOOM_CONSTANT = 800.0
def _compute_zoom_factor(): def _compute_zoom_factor():
screen_width = gtk.gdk.screen_width() screen_width = gtk.gdk.screen_width()
@ -73,7 +73,8 @@ def _compute_zoom_factor():
else: else:
return min(_MAX_ZOOM_FACTOR, screen_width / _ZOOM_CONSTANT) return min(_MAX_ZOOM_FACTOR, screen_width / _ZOOM_CONSTANT)
_dpi_factor = float(_sugar.get_screen_dpi()) / 201.0 _screen_dpi = float(_sugar.get_screen_dpi())
_dpi_factor = _screen_dpi / 201.0
_zoom_factor = _compute_zoom_factor() _zoom_factor = _compute_zoom_factor()
STANDARD_ICON_SCALE = 1.0 * _dpi_factor * _zoom_factor STANDARD_ICON_SCALE = 1.0 * _dpi_factor * _zoom_factor
@ -82,9 +83,12 @@ MEDIUM_ICON_SCALE = 1.5 * _dpi_factor * _zoom_factor
LARGE_ICON_SCALE = 2.0 * _dpi_factor * _zoom_factor LARGE_ICON_SCALE = 2.0 * _dpi_factor * _zoom_factor
XLARGE_ICON_SCALE = 3.0 * _dpi_factor * _zoom_factor XLARGE_ICON_SCALE = 3.0 * _dpi_factor * _zoom_factor
def points_to_pixels(points): def points_to_device(points):
return int(points * _zoom_factor) return int(points * _zoom_factor)
def points_to_pixels(points):
return int(points * _screen_dpi / 72.0 * _zoom_factor)
def grid_to_pixels(units): def grid_to_pixels(units):
return int(units * 75.0 * _dpi_factor * _zoom_factor) return int(units * 75.0 * _dpi_factor * _zoom_factor)

View File

@ -1,6 +1,6 @@
VERSION=0.63 VERSION=0.63
DATE=`date +%Y%m%d` DATE=`date +%Y%m%d`
RELEASE=2.25 RELEASE=2.29
TARBALL=sugar-$VERSION-$RELEASE.${DATE}git.tar.bz2 TARBALL=sugar-$VERSION-$RELEASE.${DATE}git.tar.bz2
rm sugar-$VERSION.tar.bz2 rm sugar-$VERSION.tar.bz2