Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/src/sugar3/graphics/colorbutton.py
diff options
context:
space:
mode:
Diffstat (limited to 'src/sugar3/graphics/colorbutton.py')
-rw-r--r--src/sugar3/graphics/colorbutton.py144
1 files changed, 72 insertions, 72 deletions
diff --git a/src/sugar3/graphics/colorbutton.py b/src/sugar3/graphics/colorbutton.py
index 84fda5a..fbda30d 100644
--- a/src/sugar3/graphics/colorbutton.py
+++ b/src/sugar3/graphics/colorbutton.py
@@ -17,8 +17,8 @@
# Boston, MA 02111-1307, USA.
import gettext
-import gtk
-import gobject
+from gi.repository import Gtk
+from gi.repository import GObject
import struct
import logging
@@ -35,8 +35,8 @@ def get_svg_color_string(color):
color.blue / 257)
-class _ColorButton(gtk.Button):
- """This is a ColorButton for Sugar. It is similar to the gtk.ColorButton,
+class _ColorButton(Gtk.Button):
+ """This is a ColorButton for Sugar. It is similar to the Gtk.ColorButton,
but does not have any alpha support.
Instead of a color selector dialog it will pop up a Sugar palette.
@@ -45,37 +45,37 @@ class _ColorButton(gtk.Button):
"""
__gtype_name__ = 'SugarColorButton'
- __gsignals__ = {'color-set': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
+ __gsignals__ = {'color-set': (GObject.SignalFlags.RUN_FIRST, None,
tuple())}
def __init__(self, **kwargs):
self._title = _('Choose a color')
- self._color = gtk.gdk.Color(0, 0, 0)
+ self._color = Gdk.Color(0, 0, 0)
self._has_palette = True
self._has_invoker = True
self._palette = None
self._accept_drag = True
self._preview = Icon(icon_name='color-preview',
- icon_size=gtk.ICON_SIZE_BUTTON)
+ icon_size=Gtk.IconSize.BUTTON)
- gobject.GObject.__init__(self, **kwargs)
+ GObject.GObject.__init__(self, **kwargs)
if self._accept_drag:
- self.drag_dest_set(gtk.DEST_DEFAULT_MOTION |
- gtk.DEST_DEFAULT_HIGHLIGHT |
- gtk.DEST_DEFAULT_DROP,
+ Gtk.drag_dest_set(self, Gtk.DEST_DEFAULT_MOTION |
+ Gtk.DEST_DEFAULT_HIGHLIGHT |
+ Gtk.DEST_DEFAULT_DROP,
[('application/x-color', 0, 0)],
- gtk.gdk.ACTION_COPY)
- self.drag_source_set(gtk.gdk.BUTTON1_MASK | gtk.gdk.BUTTON3_MASK,
+ Gdk.DragAction.COPY)
+ self.drag_source_set(Gdk.EventMask.BUTTON1_MASK | Gdk.EventMask.BUTTON3_MASK,
[('application/x-color', 0, 0)],
- gtk.gdk.ACTION_COPY)
+ Gdk.DragAction.COPY)
self.connect('drag_data_received', self.__drag_data_received_cb)
self.connect('drag_data_get', self.__drag_data_get_cb)
self._preview.fill_color = get_svg_color_string(self._color)
self._preview.stroke_color = \
- get_svg_color_string(self.style.fg[gtk.STATE_NORMAL])
+ get_svg_color_string(self.style.fg[Gtk.StateType.NORMAL])
self.set_image(self._preview)
if self._has_palette and self._has_invoker:
@@ -102,7 +102,7 @@ class _ColorButton(gtk.Button):
def do_style_set(self, previous_style):
self._preview.stroke_color = \
- get_svg_color_string(self.style.fg[gtk.STATE_NORMAL])
+ get_svg_color_string(self.style.fg[Gtk.StateType.NORMAL])
def do_clicked(self):
if self._palette:
@@ -114,14 +114,14 @@ class _ColorButton(gtk.Button):
return True
def set_color(self, color):
- assert isinstance(color, gtk.gdk.Color)
+ assert isinstance(color, Gdk.Color)
if self._color.red == color.red and \
self._color.green == color.green and \
self._color.blue == color.blue:
return
- self._color = gtk.gdk.Color(color.red, color.green, color.blue)
+ self._color = Gdk.Color(color.red, color.green, color.blue)
self._preview.fill_color = get_svg_color_string(self._color)
if self._palette:
self._palette.props.color = self._color
@@ -130,7 +130,7 @@ class _ColorButton(gtk.Button):
def get_color(self):
return self._color
- color = gobject.property(type=object, getter=get_color, setter=set_color)
+ color = GObject.property(type=object, getter=get_color, setter=set_color)
def set_icon_name(self, icon_name):
self._preview.props.icon_name = icon_name
@@ -138,7 +138,7 @@ class _ColorButton(gtk.Button):
def get_icon_name(self):
return self._preview.props.icon_name
- icon_name = gobject.property(type=str,
+ icon_name = GObject.property(type=str,
getter=get_icon_name, setter=set_icon_name)
def set_icon_size(self, icon_size):
@@ -147,7 +147,7 @@ class _ColorButton(gtk.Button):
def get_icon_size(self):
return self._preview.props.icon_size
- icon_size = gobject.property(type=int,
+ icon_size = GObject.property(type=int,
getter=get_icon_size, setter=set_icon_size)
def set_title(self, title):
@@ -158,7 +158,7 @@ class _ColorButton(gtk.Button):
def get_title(self):
return self._title
- title = gobject.property(type=str, getter=get_title, setter=set_title)
+ title = GObject.property(type=str, getter=get_title, setter=set_title)
def _set_has_invoker(self, has_invoker):
self._has_invoker = has_invoker
@@ -166,9 +166,9 @@ class _ColorButton(gtk.Button):
def _get_has_invoker(self):
return self._has_invoker
- has_invoker = gobject.property(type=bool, default=True,
- flags=gobject.PARAM_READWRITE |
- gobject.PARAM_CONSTRUCT_ONLY,
+ has_invoker = GObject.property(type=bool, default=True,
+ flags=GObject.PARAM_READWRITE |
+ GObject.PARAM_CONSTRUCT_ONLY,
getter=_get_has_invoker,
setter=_set_has_invoker)
@@ -178,9 +178,9 @@ class _ColorButton(gtk.Button):
def _get_has_palette(self):
return self._has_palette
- has_palette = gobject.property(type=bool, default=True,
- flags=gobject.PARAM_READWRITE |
- gobject.PARAM_CONSTRUCT_ONLY,
+ has_palette = GObject.property(type=bool, default=True,
+ flags=GObject.PARAM_READWRITE |
+ GObject.PARAM_CONSTRUCT_ONLY,
getter=_get_has_palette,
setter=_set_has_palette)
@@ -190,15 +190,15 @@ class _ColorButton(gtk.Button):
def _get_accept_drag(self):
return self._accept_drag
- accept_drag = gobject.property(type=bool, default=True,
- flags=gobject.PARAM_READWRITE |
- gobject.PARAM_CONSTRUCT_ONLY,
+ accept_drag = GObject.property(type=bool, default=True,
+ flags=GObject.PARAM_READWRITE |
+ GObject.PARAM_CONSTRUCT_ONLY,
getter=_get_accept_drag,
setter=_set_accept_drag)
def __drag_begin_cb(self, widget, context):
# Drag and Drop
- pixbuf = gtk.gdk.Pixbuf(gtk.gdk.COLORSPACE_RGB, True, 8,
+ pixbuf = GdkPixbuf.Pixbuf(GdkPixbuf.Colorspace.RGB, True, 8,
style.SMALL_ICON_SIZE,
style.SMALL_ICON_SIZE)
@@ -226,7 +226,7 @@ class _ColorButton(gtk.Button):
blue = struct.unpack_from('=H', dropped, 4)[0]
# dropped[6] and dropped[7] is alpha, but we ignore the alpha channel
- color = gtk.gdk.Color(red, green, blue)
+ color = Gdk.Color(red, green, blue)
self.set_color(color)
@@ -242,11 +242,11 @@ class _ColorPalette(Palette):
# The color-set signal is emitted when the user is finished selecting
# a color.
- __gsignals__ = {'color-set': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
+ __gsignals__ = {'color-set': (GObject.SignalFlags.RUN_FIRST, None,
tuple())}
def __init__(self, **kwargs):
- self._color = gtk.gdk.Color(0, 0, 0)
+ self._color = Gdk.Color(0, 0, 0)
self._previous_color = self._color.copy()
self._scales = None
@@ -255,16 +255,16 @@ class _ColorPalette(Palette):
self.connect('popup', self.__popup_cb)
self.connect('popdown', self.__popdown_cb)
- self._picker_hbox = gtk.HBox()
+ self._picker_hbox = Gtk.HBox()
self.set_content(self._picker_hbox)
- self._swatch_tray = gtk.Table()
+ self._swatch_tray = Gtk.Table()
- self._picker_hbox.pack_start(self._swatch_tray)
- self._picker_hbox.pack_start(gtk.VSeparator(),
+ self._picker_hbox.pack_start(self._swatch_tray, True, True, 0)
+ self._picker_hbox.pack_start(Gtk.VSeparator(, True, True, 0),
padding=style.DEFAULT_SPACING)
- self._chooser_table = gtk.Table(3, 2)
+ self._chooser_table = Gtk.Table(3, 2)
self._chooser_table.set_col_spacing(0, style.DEFAULT_PADDING)
self._scales = []
@@ -282,9 +282,9 @@ class _ColorPalette(Palette):
self._build_swatches()
def _create_color_scale(self, text, color, row):
- label = gtk.Label(text)
+ label = Gtk.Label(label=text)
label.props.xalign = 1.0
- scale = gtk.HScale()
+ scale = Gtk.HScale()
scale.set_size_request(style.zoom(250), -1)
scale.set_draw_value(False)
scale.set_range(0, 1.0)
@@ -322,10 +322,10 @@ class _ColorPalette(Palette):
self._swatch_tray.props.n_columns = (len(colors) + rows - 1) / rows
for color in colors:
button = _ColorButton(has_palette=False,
- color=gtk.gdk.color_parse(color),
+ color=Gdk.color_parse(color),
accept_drag=False,
- icon_size=gtk.ICON_SIZE_LARGE_TOOLBAR)
- button.set_relief(gtk.RELIEF_NONE)
+ icon_size=Gtk.IconSize.LARGE_TOOLBAR)
+ button.set_relief(Gtk.ReliefStyle.NONE)
self._swatch_tray.attach(button,
i % rows, i % rows + 1,
i / rows, i / rows + 1,
@@ -352,11 +352,11 @@ class _ColorPalette(Palette):
self.color = new_color
def do_key_press_event(self, event):
- if event.keyval == gtk.keysyms.Escape:
+ if event.keyval == Gdk.KEY_Escape:
self.props.color = self._previous_color
self.popdown(immediate=True)
return True
- elif event.keyval == gtk.keysyms.Return:
+ elif event.keyval == Gdk.KEY_Return:
self.popdown(immediate=True)
return True
return False
@@ -365,7 +365,7 @@ class _ColorPalette(Palette):
self.props.color = button.get_color()
def set_color(self, color):
- assert isinstance(color, gtk.gdk.Color)
+ assert isinstance(color, Gdk.Color)
if self._color.red == color.red and \
self._color.green == color.green and \
@@ -384,26 +384,26 @@ class _ColorPalette(Palette):
def get_color(self):
return self._color
- color = gobject.property(type=object, getter=get_color, setter=set_color)
+ color = GObject.property(type=object, getter=get_color, setter=set_color)
def _add_accelerator(tool_button):
if not tool_button.props.accelerator or not tool_button.get_toplevel() or \
- not tool_button.child:
+ not tool_button.get_child():
return
# TODO: should we remove the accelerator from the prev top level?
accel_group = tool_button.get_toplevel().get_data('sugar-accel-group')
if not accel_group:
- logging.warning('No gtk.AccelGroup in the top level window.')
+ logging.warning('No Gtk.AccelGroup in the top level window.')
return
- keyval, mask = gtk.accelerator_parse(tool_button.props.accelerator)
- # the accelerator needs to be set at the child, so the gtk.AccelLabel
+ keyval, mask = Gtk.accelerator_parse(tool_button.props.accelerator)
+ # the accelerator needs to be set at the child, so the Gtk.AccelLabel
# in the palette can pick it up.
- tool_button.child.add_accelerator('clicked', accel_group, keyval, mask,
- gtk.ACCEL_LOCKED | gtk.ACCEL_VISIBLE)
+ tool_button.get_child().add_accelerator('clicked', accel_group, keyval, mask,
+ Gtk.AccelFlags.LOCKED | Gtk.AccelFlags.VISIBLE)
def _hierarchy_changed_cb(tool_button, previous_toplevel):
@@ -415,13 +415,13 @@ def setup_accelerator(tool_button):
tool_button.connect('hierarchy-changed', _hierarchy_changed_cb)
-class ColorToolButton(gtk.ToolItem):
- # This not ideal. It would be better to subclass gtk.ToolButton, however
+class ColorToolButton(Gtk.ToolItem):
+ # This not ideal. It would be better to subclass Gtk.ToolButton, however
# the python bindings do not seem to be powerfull enough for that.
# (As we need to change a variable in the class structure.)
__gtype_name__ = 'SugarColorToolButton'
- __gsignals__ = {'color-set': (gobject.SIGNAL_RUN_FIRST, gobject.TYPE_NONE,
+ __gsignals__ = {'color-set': (GObject.SignalFlags.RUN_FIRST, None,
tuple())}
def __init__(self, icon_name='color-preview', **kwargs):
@@ -430,16 +430,16 @@ class ColorToolButton(gtk.ToolItem):
self._palette_invoker = ToolInvoker()
self._palette = None
- gobject.GObject.__init__(self, **kwargs)
+ GObject.GObject.__init__(self, **kwargs)
- # The gtk.ToolButton has already added a normal button.
+ # The Gtk.ToolButton has already added a normal button.
# Replace it with a ColorButton
color_button = _ColorButton(icon_name=icon_name, has_invoker=False)
self.add(color_button)
# The following is so that the behaviour on the toolbar is correct.
- color_button.set_relief(gtk.RELIEF_NONE)
- color_button.icon_size = gtk.ICON_SIZE_LARGE_TOOLBAR
+ color_button.set_relief(Gtk.ReliefStyle.NONE)
+ color_button.icon_size = Gtk.IconSize.LARGE_TOOLBAR
self._palette_invoker.attach_tool(self)
@@ -463,7 +463,7 @@ class ColorToolButton(gtk.ToolItem):
def get_accelerator(self):
return self._accelerator
- accelerator = gobject.property(type=str, setter=set_accelerator,
+ accelerator = GObject.property(type=str, setter=set_accelerator,
getter=get_accelerator)
def create_palette(self):
@@ -477,7 +477,7 @@ class ColorToolButton(gtk.ToolItem):
self._palette_invoker.detach()
self._palette_invoker = palette_invoker
- palette_invoker = gobject.property(
+ palette_invoker = GObject.property(
type=object, setter=set_palette_invoker, getter=get_palette_invoker)
def set_color(self, color):
@@ -486,7 +486,7 @@ class ColorToolButton(gtk.ToolItem):
def get_color(self):
return self.get_child().props.color
- color = gobject.property(type=object, getter=get_color, setter=set_color)
+ color = GObject.property(type=object, getter=get_color, setter=set_color)
def set_icon_name(self, icon_name):
self.get_child().props.icon_name = icon_name
@@ -494,7 +494,7 @@ class ColorToolButton(gtk.ToolItem):
def get_icon_name(self):
return self.get_child().props.icon_name
- icon_name = gobject.property(type=str,
+ icon_name = GObject.property(type=str,
getter=get_icon_name, setter=set_icon_name)
def set_icon_size(self, icon_size):
@@ -503,7 +503,7 @@ class ColorToolButton(gtk.ToolItem):
def get_icon_size(self):
return self.get_child().props.icon_size
- icon_size = gobject.property(type=int,
+ icon_size = GObject.property(type=int,
getter=get_icon_size, setter=set_icon_size)
def set_title(self, title):
@@ -512,7 +512,7 @@ class ColorToolButton(gtk.ToolItem):
def get_title(self):
return self.get_child().props.title
- title = gobject.property(type=str, getter=get_title, setter=set_title)
+ title = GObject.property(type=str, getter=get_title, setter=set_title)
def do_expose_event(self, event):
child = self.get_child()
@@ -520,14 +520,14 @@ class ColorToolButton(gtk.ToolItem):
if self._palette and self._palette.is_up():
invoker = self._palette.props.invoker
invoker.draw_rectangle(event, self._palette)
- elif child.state == gtk.STATE_PRELIGHT:
- child.style.paint_box(event.window, gtk.STATE_PRELIGHT,
- gtk.SHADOW_NONE, event.area,
+ elif child.state == Gtk.StateType.PRELIGHT:
+ child.style.paint_box(event.window, Gtk.StateType.PRELIGHT,
+ Gtk.ShadowType.NONE, event.area,
child, 'toolbutton-prelight',
allocation.x, allocation.y,
allocation.width, allocation.height)
- gtk.ToolButton.do_expose_event(self, event)
+ Gtk.ToolButton.do_expose_event(self, event)
def __notify_change(self, widget, pspec):
self.notify(pspec.name)