Rework color and fonts to be more pytonish. Add units conversions.
This commit is contained in:
parent
32c89a1fcb
commit
2e8bd12f8b
@ -4,8 +4,10 @@ sugar_PYTHON = \
|
|||||||
bubble.py \
|
bubble.py \
|
||||||
button.py \
|
button.py \
|
||||||
canvasicon.py \
|
canvasicon.py \
|
||||||
|
color.py \
|
||||||
ClipboardBubble.py \
|
ClipboardBubble.py \
|
||||||
entry.py \
|
entry.py \
|
||||||
|
font.py \
|
||||||
frame.py \
|
frame.py \
|
||||||
grid.py \
|
grid.py \
|
||||||
iconcolor.py \
|
iconcolor.py \
|
||||||
@ -20,4 +22,5 @@ sugar_PYTHON = \
|
|||||||
style.py \
|
style.py \
|
||||||
stylesheet.py \
|
stylesheet.py \
|
||||||
timeline.py \
|
timeline.py \
|
||||||
toolbar.py
|
toolbar.py \
|
||||||
|
units.py
|
||||||
|
81
sugar/graphics/color.py
Normal file
81
sugar/graphics/color.py
Normal file
@ -0,0 +1,81 @@
|
|||||||
|
import gtk
|
||||||
|
|
||||||
|
_system_colors = {
|
||||||
|
'toolbar-background' : '#414141',
|
||||||
|
'frame-border' : '#D1D1D2',
|
||||||
|
'entry-background-focused' : '#FFFFFF',
|
||||||
|
'entry-background-unfocused' : '#414141',
|
||||||
|
'entry-selection-focused' : '#D1D1D2',
|
||||||
|
'entry-selection-unfocused' : '#00FF00',
|
||||||
|
'entry-text-focused' : '#000000',
|
||||||
|
'entry-text-unfocused' : '#FFFFFF',
|
||||||
|
'entry-border' : '#D1D1D2',
|
||||||
|
'label-text' : '#FFFFFF',
|
||||||
|
'desktop-background' : '#E2E2E3',
|
||||||
|
'menu-background' : '#414141',
|
||||||
|
'menu-separator' : '#D1D1D2',
|
||||||
|
'menu-border' : '#D1D1D2'
|
||||||
|
}
|
||||||
|
|
||||||
|
def _html_to_rgb(html_color):
|
||||||
|
""" #RRGGBB -> (r, g, b) tuple (in float format) """
|
||||||
|
|
||||||
|
html_color = html_color.strip()
|
||||||
|
if html_color[0] == '#':
|
||||||
|
html_color = html_color[1:]
|
||||||
|
if len(html_color) != 6:
|
||||||
|
raise ValueError, "input #%s is not in #RRGGBB format" % html_color
|
||||||
|
|
||||||
|
r, g, b = html_color[:2], html_color[2:4], html_color[4:]
|
||||||
|
r, g, b = [int(n, 16) for n in (r, g, b)]
|
||||||
|
r, g, b = (r / 255.0, g / 255.0, b / 255.0)
|
||||||
|
|
||||||
|
return (r, g, b)
|
||||||
|
|
||||||
|
def _rgba_to_int(r, g, b, a):
|
||||||
|
color = int(a * 255) + (int(b * 255) << 8) + \
|
||||||
|
(int(g * 255) << 16) + (int(r * 255) << 24)
|
||||||
|
return color
|
||||||
|
|
||||||
|
class RGBColor(object):
|
||||||
|
def __init__(self, r, g, b, a=1.0):
|
||||||
|
self._r = r
|
||||||
|
self._g = g
|
||||||
|
self._b = b
|
||||||
|
self._a = a
|
||||||
|
|
||||||
|
def get_rgba(self):
|
||||||
|
return (self._r, self._g, self._b, self._a)
|
||||||
|
|
||||||
|
def get_int(self):
|
||||||
|
return _rgba_to_int(self._r, self._g, self._b, self._a)
|
||||||
|
|
||||||
|
def get_gdk_color(self):
|
||||||
|
return gtk.gdk.Color(int(self._r * 65535), int(self._g * 65535),
|
||||||
|
int(self._b * 65535))
|
||||||
|
|
||||||
|
class SystemColor(RGBColor):
|
||||||
|
def __init__(self, color_id):
|
||||||
|
rgb = _html_to_rgb(_system_colors[color_id])
|
||||||
|
RGBColor.__init__(self, *rgb)
|
||||||
|
|
||||||
|
RED = RGBColor(1.0, 0.0, 0.0)
|
||||||
|
GREEN = RGBColor(0.0, 1.0, 0.0)
|
||||||
|
BLUE = RGBColor(0.0, 0.0, 1.0)
|
||||||
|
WHITE = RGBColor(1.0, 1.0, 1.0)
|
||||||
|
BLACK = RGBColor(0.0, 0.0, 0.0)
|
||||||
|
|
||||||
|
TOOLBAR_BACKGROUND = SystemColor('toolbar-background')
|
||||||
|
FRAME_BORDER = SystemColor('frame-border')
|
||||||
|
ENTRY_BACKGROUND_FOCUSED = SystemColor('entry-background-focused')
|
||||||
|
ENTRY_BACKGROUND_UNFOCUSED = SystemColor('entry-background-unfocused')
|
||||||
|
ENTRY_SELECTION_FOCUSED = SystemColor('entry-selection-focused')
|
||||||
|
ENTRY_SELECTION_UNFOCUSED = SystemColor('entry-selection-unfocused')
|
||||||
|
ENTRY_TEXT_FOCUSED = SystemColor('entry-text-focused')
|
||||||
|
ENTRY_TEXT_UNFOCUSED = SystemColor('entry-text-unfocused')
|
||||||
|
ENTRY_BORDER = SystemColor('entry-border')
|
||||||
|
LABEL_TEXT = SystemColor('label-text')
|
||||||
|
DESKTOP_BACKGROUND = SystemColor('desktop-background')
|
||||||
|
MENU_BACKGROUND = SystemColor('menu-background')
|
||||||
|
MENU_SEPARATOR = SystemColor('menu-separator')
|
||||||
|
MENU_BORDER = SystemColor('menu-border')
|
@ -22,8 +22,8 @@ import gtk
|
|||||||
import hippo
|
import hippo
|
||||||
|
|
||||||
from sugar.graphics import style
|
from sugar.graphics import style
|
||||||
from sugar.graphics.style import Color
|
from sugar.graphics import color
|
||||||
from sugar.graphics.style import Font
|
from sugar.graphics import font
|
||||||
from sugar.graphics.button import Button
|
from sugar.graphics.button import Button
|
||||||
from sugar.graphics.roundbox import RoundBox
|
from sugar.graphics.roundbox import RoundBox
|
||||||
|
|
||||||
@ -57,7 +57,7 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
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)
|
self._entry.connect('activate', self._entry_activate_cb)
|
||||||
self._entry.modify_font(Font.DEFAULT.get_pango_desc())
|
self._entry.modify_font(font.DEFAULT.get_pango_desc())
|
||||||
|
|
||||||
self._canvas_widget = hippo.CanvasWidget()
|
self._canvas_widget = hippo.CanvasWidget()
|
||||||
self._canvas_widget.props.widget = self._entry
|
self._canvas_widget.props.widget = self._entry
|
||||||
@ -105,21 +105,21 @@ class Entry(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
def _update_colors(self, focused):
|
def _update_colors(self, focused):
|
||||||
if focused:
|
if focused:
|
||||||
self._round_box.props.background_color = \
|
self._round_box.props.background_color = \
|
||||||
Color.ENTRY_BACKGROUND_FOCUSED.get_int()
|
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())
|
||||||
self._entry.modify_base(gtk.STATE_SELECTED,
|
self._entry.modify_base(gtk.STATE_SELECTED,
|
||||||
Color.ENTRY_SELECTION_FOCUSED.get_gdk_color())
|
color.ENTRY_SELECTION_FOCUSED.get_gdk_color())
|
||||||
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._round_box.props.background_color = \
|
self._round_box.props.background_color = \
|
||||||
Color.ENTRY_BACKGROUND_UNFOCUSED.get_int()
|
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())
|
||||||
self._entry.modify_base(gtk.STATE_SELECTED,
|
self._entry.modify_base(gtk.STATE_SELECTED,
|
||||||
Color.ENTRY_SELECTION_UNFOCUSED.get_gdk_color())
|
color.ENTRY_SELECTION_UNFOCUSED.get_gdk_color())
|
||||||
self._entry.modify_text(gtk.STATE_NORMAL,
|
self._entry.modify_text(gtk.STATE_NORMAL,
|
||||||
Color.ENTRY_TEXT_UNFOCUSED.get_gdk_color())
|
color.ENTRY_TEXT_UNFOCUSED.get_gdk_color())
|
||||||
|
23
sugar/graphics/font.py
Normal file
23
sugar/graphics/font.py
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
import pango
|
||||||
|
|
||||||
|
from sugar.graphics import units
|
||||||
|
|
||||||
|
_system_fonts = {
|
||||||
|
'default' : 'Bitstream Vera Sans %d' % units.points_to_pixels(9)
|
||||||
|
}
|
||||||
|
|
||||||
|
class Font(object):
|
||||||
|
def __init__(self, desc):
|
||||||
|
self._desc = desc
|
||||||
|
|
||||||
|
def get_desc(self):
|
||||||
|
return self._desc
|
||||||
|
|
||||||
|
def get_pango_desc(self):
|
||||||
|
return pango.FontDescription(self._desc)
|
||||||
|
|
||||||
|
class SystemFont(Font):
|
||||||
|
def __init__(self, font_id):
|
||||||
|
Font.__init__(self, _system_fonts[font_id])
|
||||||
|
|
||||||
|
DEFAULT = SystemFont('default')
|
@ -15,7 +15,7 @@
|
|||||||
# 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.
|
||||||
|
|
||||||
from sugar.graphics.style import Color
|
from sugar.graphics import color
|
||||||
from sugar.graphics.roundbox import RoundBox
|
from sugar.graphics.roundbox import RoundBox
|
||||||
|
|
||||||
class Frame(RoundBox):
|
class Frame(RoundBox):
|
||||||
@ -23,4 +23,4 @@ class Frame(RoundBox):
|
|||||||
|
|
||||||
def __init__(self, **kwargs):
|
def __init__(self, **kwargs):
|
||||||
RoundBox.__init__(self, **kwargs)
|
RoundBox.__init__(self, **kwargs)
|
||||||
self.props.border_color = Color.FRAME_BORDER.get_int()
|
self.props.border_color = color.FRAME_BORDER.get_int()
|
||||||
|
@ -24,8 +24,8 @@ import hippo
|
|||||||
from sugar.graphics import style
|
from sugar.graphics import style
|
||||||
from sugar.graphics.roundbox import RoundBox
|
from sugar.graphics.roundbox import RoundBox
|
||||||
from sugar.graphics.button import Button
|
from sugar.graphics.button import Button
|
||||||
from sugar.graphics.style import Color
|
from sugar.graphics import color
|
||||||
from sugar.graphics.font import Font
|
from sugar.graphics import font
|
||||||
|
|
||||||
class Label(hippo.CanvasBox, hippo.CanvasItem):
|
class Label(hippo.CanvasBox, hippo.CanvasItem):
|
||||||
__gtype_name__ = 'SugarLabel'
|
__gtype_name__ = 'SugarLabel'
|
||||||
@ -42,13 +42,13 @@ class Label(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
self._text = text
|
self._text = text
|
||||||
|
|
||||||
self._round_box = RoundBox()
|
self._round_box = RoundBox()
|
||||||
self._round_box.props.border_color = Color.FRAME_BORDER.get_int()
|
self._round_box.props.border_color = color.FRAME_BORDER.get_int()
|
||||||
self.append(self._round_box, hippo.PACK_EXPAND)
|
self.append(self._round_box, hippo.PACK_EXPAND)
|
||||||
|
|
||||||
self._canvas_text = hippo.CanvasText()
|
self._canvas_text = hippo.CanvasText()
|
||||||
self._canvas_text.props.text = self._text
|
self._canvas_text.props.text = self._text
|
||||||
self._canvas_text.props.color = Color.LABEL_TEXT.get_int()
|
self._canvas_text.props.color = color.LABEL_TEXT.get_int()
|
||||||
self._canvas_text.props.font_desc = Font.DEFAULT.get_pango_desc()
|
self._canvas_text.props.font_desc = font.DEFAULT.get_pango_desc()
|
||||||
self._round_box.append(self._canvas_text, hippo.PACK_EXPAND)
|
self._round_box.append(self._canvas_text, hippo.PACK_EXPAND)
|
||||||
|
|
||||||
def do_set_property(self, pspec, value):
|
def do_set_property(self, pspec, value):
|
||||||
|
@ -25,8 +25,8 @@ import hippo
|
|||||||
from sugar.graphics import style
|
from sugar.graphics import style
|
||||||
from sugar.graphics.roundbox import RoundBox
|
from sugar.graphics.roundbox import RoundBox
|
||||||
from sugar.graphics.button import Button
|
from sugar.graphics.button import Button
|
||||||
from sugar.graphics.style import Color
|
from sugar.graphics import color
|
||||||
from sugar.graphics.style import Font
|
from sugar.graphics import font
|
||||||
from sugar.graphics.canvasicon import CanvasIcon
|
from sugar.graphics.canvasicon import CanvasIcon
|
||||||
|
|
||||||
class Menu(hippo.CanvasBox, hippo.CanvasItem):
|
class Menu(hippo.CanvasBox, hippo.CanvasItem):
|
||||||
@ -38,8 +38,8 @@ class Menu(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
hippo.CanvasBox.__init__(self)
|
hippo.CanvasBox.__init__(self)
|
||||||
self.props.background_color = Color.MENU_BACKGROUND.get_int()
|
self.props.background_color = color.MENU_BACKGROUND.get_int()
|
||||||
self.props.border_color = Color.MENU_BORDER.get_int()
|
self.props.border_color = color.MENU_BORDER.get_int()
|
||||||
#TODO: how we should specify the border thickness?
|
#TODO: how we should specify the border thickness?
|
||||||
self.props.border = style.separator_thickness
|
self.props.border = style.separator_thickness
|
||||||
self._window = None
|
self._window = None
|
||||||
@ -56,8 +56,8 @@ class Menu(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
|
|
||||||
canvas_text = hippo.CanvasText()
|
canvas_text = hippo.CanvasText()
|
||||||
canvas_text.props.text = label
|
canvas_text.props.text = label
|
||||||
canvas_text.props.color = Color.LABEL_TEXT.get_int()
|
canvas_text.props.color = color.LABEL_TEXT.get_int()
|
||||||
canvas_text.props.font_desc = Font.DEFAULT.get_pango_desc()
|
canvas_text.props.font_desc = font.DEFAULT.get_pango_desc()
|
||||||
box.append(canvas_text)
|
box.append(canvas_text)
|
||||||
|
|
||||||
box.connect('button-press-event', self._button_press_event_cb, action_id)
|
box.connect('button-press-event', self._button_press_event_cb, action_id)
|
||||||
@ -65,7 +65,7 @@ class Menu(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
|
|
||||||
def add_separator(self):
|
def add_separator(self):
|
||||||
box = hippo.CanvasBox()
|
box = hippo.CanvasBox()
|
||||||
box.props.background_color = Color.MENU_SEPARATOR.get_int()
|
box.props.background_color = color.MENU_SEPARATOR.get_int()
|
||||||
box.props.box_height = style.separator_thickness
|
box.props.box_height = style.separator_thickness
|
||||||
self.append(box)
|
self.append(box)
|
||||||
|
|
||||||
@ -105,13 +105,13 @@ class OptionMenu(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
self._value = None
|
self._value = None
|
||||||
|
|
||||||
self._round_box = RoundBox()
|
self._round_box = RoundBox()
|
||||||
self._round_box.props.border_color = Color.FRAME_BORDER.get_int()
|
self._round_box.props.border_color = color.FRAME_BORDER.get_int()
|
||||||
self.append(self._round_box, hippo.PACK_EXPAND)
|
self.append(self._round_box, hippo.PACK_EXPAND)
|
||||||
|
|
||||||
self._canvas_text = hippo.CanvasText()
|
self._canvas_text = hippo.CanvasText()
|
||||||
self._canvas_text.props.text = _('No options')
|
self._canvas_text.props.text = _('No options')
|
||||||
self._canvas_text.props.color = Color.LABEL_TEXT.get_int()
|
self._canvas_text.props.color = color.LABEL_TEXT.get_int()
|
||||||
self._canvas_text.props.font_desc = Font.DEFAULT.get_pango_desc()
|
self._canvas_text.props.font_desc = font.DEFAULT.get_pango_desc()
|
||||||
self._round_box.append(self._canvas_text, hippo.PACK_EXPAND)
|
self._round_box.append(self._canvas_text, hippo.PACK_EXPAND)
|
||||||
|
|
||||||
# TODO: Substitute for the right icon.
|
# TODO: Substitute for the right icon.
|
||||||
|
@ -20,7 +20,7 @@ import math
|
|||||||
import hippo
|
import hippo
|
||||||
|
|
||||||
from sugar.graphics import style
|
from sugar.graphics import style
|
||||||
from sugar.graphics.style import Color
|
from sugar.graphics import color
|
||||||
|
|
||||||
class RoundBox(hippo.CanvasBox, hippo.CanvasItem):
|
class RoundBox(hippo.CanvasBox, hippo.CanvasItem):
|
||||||
__gtype_name__ = 'SugarRoundBox'
|
__gtype_name__ = 'SugarRoundBox'
|
||||||
@ -38,7 +38,7 @@ class RoundBox(hippo.CanvasBox, hippo.CanvasItem):
|
|||||||
self.props.border_bottom = self._BORDER_DEFAULT
|
self.props.border_bottom = self._BORDER_DEFAULT
|
||||||
self.props.border_left = self._radius
|
self.props.border_left = self._radius
|
||||||
self.props.border_right = self._radius
|
self.props.border_right = self._radius
|
||||||
self.props.border_color = Color.BLACK.get_int()
|
self.props.border_color = color.BLACK.get_int()
|
||||||
|
|
||||||
def do_paint_background(self, cr, damaged_box):
|
def do_paint_background(self, cr, damaged_box):
|
||||||
[width, height] = self.get_allocation()
|
[width, height] = self.get_allocation()
|
||||||
|
@ -16,119 +16,8 @@
|
|||||||
# Boston, MA 02111-1307, USA.
|
# Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
import logging
|
import logging
|
||||||
import math
|
|
||||||
|
|
||||||
import gtk
|
import gtk
|
||||||
import pango
|
|
||||||
|
|
||||||
import _sugar
|
|
||||||
|
|
||||||
_screen_factor = gtk.gdk.screen_width() / 1200.0
|
|
||||||
_dpi_factor = _sugar.get_screen_dpi() / 201.0
|
|
||||||
_default_font_size = math.ceil(9 / _dpi_factor * _screen_factor)
|
|
||||||
print _default_font_size
|
|
||||||
|
|
||||||
_system_colors = {
|
|
||||||
'toolbar-background' : '#414141',
|
|
||||||
'frame-border' : '#D1D1D2',
|
|
||||||
'entry-background-focused' : '#FFFFFF',
|
|
||||||
'entry-background-unfocused' : '#414141',
|
|
||||||
'entry-selection-focused' : '#D1D1D2',
|
|
||||||
'entry-selection-unfocused' : '#00FF00',
|
|
||||||
'entry-text-focused' : '#000000',
|
|
||||||
'entry-text-unfocused' : '#FFFFFF',
|
|
||||||
'entry-border' : '#D1D1D2',
|
|
||||||
'label-text' : '#FFFFFF',
|
|
||||||
'desktop-background' : '#E2E2E3',
|
|
||||||
'menu-background' : '#414141',
|
|
||||||
'menu-separator' : '#D1D1D2',
|
|
||||||
'menu-border' : '#D1D1D2'
|
|
||||||
}
|
|
||||||
|
|
||||||
def _html_to_rgb(html_color):
|
|
||||||
""" #RRGGBB -> (r, g, b) tuple (in float format) """
|
|
||||||
|
|
||||||
html_color = html_color.strip()
|
|
||||||
if html_color[0] == '#':
|
|
||||||
html_color = html_color[1:]
|
|
||||||
if len(html_color) != 6:
|
|
||||||
raise ValueError, "input #%s is not in #RRGGBB format" % html_color
|
|
||||||
|
|
||||||
r, g, b = html_color[:2], html_color[2:4], html_color[4:]
|
|
||||||
r, g, b = [int(n, 16) for n in (r, g, b)]
|
|
||||||
r, g, b = (r / 255.0, g / 255.0, b / 255.0)
|
|
||||||
|
|
||||||
return (r, g, b)
|
|
||||||
|
|
||||||
def _rgba_to_int(r, g, b, a):
|
|
||||||
color = int(a * 255) + (int(b * 255) << 8) + \
|
|
||||||
(int(g * 255) << 16) + (int(r * 255) << 24)
|
|
||||||
return color
|
|
||||||
|
|
||||||
class RGBColor(object):
|
|
||||||
def __init__(self, r, g, b, a=1.0):
|
|
||||||
self._r = r
|
|
||||||
self._g = g
|
|
||||||
self._b = b
|
|
||||||
self._a = a
|
|
||||||
|
|
||||||
def get_rgba(self):
|
|
||||||
return (self._r, self._g, self._b, self._a)
|
|
||||||
|
|
||||||
def get_int(self):
|
|
||||||
return _rgba_to_int(self._r, self._g, self._b, self._a)
|
|
||||||
|
|
||||||
def get_gdk_color(self):
|
|
||||||
return gtk.gdk.Color(int(self._r * 65535), int(self._g * 65535),
|
|
||||||
int(self._b * 65535))
|
|
||||||
|
|
||||||
class SystemColor(RGBColor):
|
|
||||||
def __init__(self, color_id):
|
|
||||||
rgb = _html_to_rgb(_system_colors[color_id])
|
|
||||||
RGBColor.__init__(self, *rgb)
|
|
||||||
|
|
||||||
class Color(object):
|
|
||||||
RED = RGBColor(1.0, 0.0, 0.0)
|
|
||||||
GREEN = RGBColor(0.0, 1.0, 0.0)
|
|
||||||
BLUE = RGBColor(0.0, 0.0, 1.0)
|
|
||||||
WHITE = RGBColor(1.0, 1.0, 1.0)
|
|
||||||
BLACK = RGBColor(0.0, 0.0, 0.0)
|
|
||||||
|
|
||||||
TOOLBAR_BACKGROUND = SystemColor('toolbar-background')
|
|
||||||
FRAME_BORDER = SystemColor('frame-border')
|
|
||||||
ENTRY_BACKGROUND_FOCUSED = SystemColor('entry-background-focused')
|
|
||||||
ENTRY_BACKGROUND_UNFOCUSED = SystemColor('entry-background-unfocused')
|
|
||||||
ENTRY_SELECTION_FOCUSED = SystemColor('entry-selection-focused')
|
|
||||||
ENTRY_SELECTION_UNFOCUSED = SystemColor('entry-selection-unfocused')
|
|
||||||
ENTRY_TEXT_FOCUSED = SystemColor('entry-text-focused')
|
|
||||||
ENTRY_TEXT_UNFOCUSED = SystemColor('entry-text-unfocused')
|
|
||||||
ENTRY_BORDER = SystemColor('entry-border')
|
|
||||||
LABEL_TEXT = SystemColor('label-text')
|
|
||||||
DESKTOP_BACKGROUND = SystemColor('desktop-background')
|
|
||||||
MENU_BACKGROUND = SystemColor('menu-background')
|
|
||||||
MENU_SEPARATOR = SystemColor('menu-separator')
|
|
||||||
MENU_BORDER = SystemColor('menu-border')
|
|
||||||
|
|
||||||
_system_fonts = {
|
|
||||||
'default' : 'Bitstream Vera Sans %d' % _default_font_size
|
|
||||||
}
|
|
||||||
|
|
||||||
class BaseFont(object):
|
|
||||||
def __init__(self, desc):
|
|
||||||
self._desc = desc
|
|
||||||
|
|
||||||
def get_desc(self):
|
|
||||||
return self._desc
|
|
||||||
|
|
||||||
def get_pango_desc(self):
|
|
||||||
return pango.FontDescription(self._desc)
|
|
||||||
|
|
||||||
class SystemFont(BaseFont):
|
|
||||||
def __init__(self, font_id):
|
|
||||||
BaseFont.__init__(self, _system_fonts[font_id])
|
|
||||||
|
|
||||||
class Font(object):
|
|
||||||
DEFAULT = SystemFont('default')
|
|
||||||
|
|
||||||
### Deprecated: we should drop this once we removed stylesheets ###
|
### Deprecated: we should drop this once we removed stylesheets ###
|
||||||
|
|
||||||
|
12
sugar/graphics/units.py
Normal file
12
sugar/graphics/units.py
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import gtk
|
||||||
|
|
||||||
|
import _sugar
|
||||||
|
|
||||||
|
def points_to_pixels(points):
|
||||||
|
return points * _sugar.get_screen_dpi() / 72.0
|
||||||
|
|
||||||
|
def grid_to_pixels(units):
|
||||||
|
return units * gtk.gdk.screen_width() / 16
|
||||||
|
|
||||||
|
def microgrid_to_pixels(units):
|
||||||
|
return units * gtk.gdk.screen_width() / 80
|
@ -22,7 +22,6 @@ 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.style import Color
|
|
||||||
|
|
||||||
def _entry_activated_cb(entry):
|
def _entry_activated_cb(entry):
|
||||||
print "_entry_activated_cb"
|
print "_entry_activated_cb"
|
||||||
|
@ -21,7 +21,6 @@ import hippo
|
|||||||
from sugar.graphics.toolbar import Toolbar
|
from sugar.graphics.toolbar import Toolbar
|
||||||
from sugar.graphics.label import Label
|
from sugar.graphics.label import Label
|
||||||
from sugar.graphics.button import Button
|
from sugar.graphics.button import Button
|
||||||
from sugar.graphics.style import Color
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
theme = gtk.icon_theme_get_default()
|
theme = gtk.icon_theme_get_default()
|
||||||
|
@ -24,7 +24,6 @@ import hippo
|
|||||||
|
|
||||||
from sugar.graphics.toolbar import Toolbar
|
from sugar.graphics.toolbar import Toolbar
|
||||||
from sugar.graphics.optionmenu import OptionMenu
|
from sugar.graphics.optionmenu import OptionMenu
|
||||||
from sugar.graphics.style import Color
|
|
||||||
from sugar.graphics.button import Button
|
from sugar.graphics.button import Button
|
||||||
|
|
||||||
def _option_menu_changed_cb(option_menu):
|
def _option_menu_changed_cb(option_menu):
|
||||||
|
Loading…
Reference in New Issue
Block a user