Some palette improvements and add palette support to CanvasIcon.
This commit is contained in:
		
							parent
							
								
									983d494d38
								
							
						
					
					
						commit
						3ca87cd46d
					
				| @ -25,30 +25,11 @@ import rsvg | |||||||
| import cairo | import cairo | ||||||
| import time | import time | ||||||
| 
 | 
 | ||||||
| from sugar.graphics.popup import Popup |  | ||||||
| from sugar.graphics import color | from sugar.graphics import color | ||||||
| from sugar.graphics.xocolor import XoColor | from sugar.graphics.xocolor import XoColor | ||||||
| from sugar.graphics import font | from sugar.graphics import font | ||||||
| from sugar.graphics import units | from sugar.graphics import units | ||||||
| from sugar.graphics import animator | from sugar.graphics.palette import Palette, CanvasInvoker | ||||||
| 
 |  | ||||||
| class _PopupAnimation(animator.Animation): |  | ||||||
|     def __init__(self, icon): |  | ||||||
|         animator.Animation.__init__(self, 0.0, 1.0) |  | ||||||
|         self._icon = icon |  | ||||||
| 
 |  | ||||||
|     def next_frame(self, current): |  | ||||||
|         if current == 1.0: |  | ||||||
|             self._icon.show_popup() |  | ||||||
| 
 |  | ||||||
| class _PopdownAnimation(animator.Animation): |  | ||||||
|     def __init__(self, icon): |  | ||||||
|         animator.Animation.__init__(self, 0.0, 1.0) |  | ||||||
|         self._icon = icon |  | ||||||
| 
 |  | ||||||
|     def next_frame(self, current): |  | ||||||
|         if current == 1.0: |  | ||||||
|             self._icon.hide_popup() |  | ||||||
| 
 | 
 | ||||||
| class _IconCacheIcon: | class _IconCacheIcon: | ||||||
|     def __init__(self, name, fill_color, stroke_color, now): |     def __init__(self, name, fill_color, stroke_color, now): | ||||||
| @ -166,8 +147,6 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem): | |||||||
|                            gobject.PARAM_READWRITE), |                            gobject.PARAM_READWRITE), | ||||||
|         'cache'         : (bool, None, None, False, |         'cache'         : (bool, None, None, False, | ||||||
|                            gobject.PARAM_READWRITE), |                            gobject.PARAM_READWRITE), | ||||||
|         'tooltip'       : (str, None, None, None, |  | ||||||
|                            gobject.PARAM_READWRITE), |  | ||||||
|         'active'        : (bool, None, None, True, |         'active'        : (bool, None, None, True, | ||||||
|                            gobject.PARAM_READWRITE) |                            gobject.PARAM_READWRITE) | ||||||
|     } |     } | ||||||
| @ -183,17 +162,10 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem): | |||||||
|         self._icon_name = None |         self._icon_name = None | ||||||
|         self._cache = False |         self._cache = False | ||||||
|         self._handle = None |         self._handle = None | ||||||
|         self._popup = None |  | ||||||
|         self._hover_icon = False |  | ||||||
|         self._hover_popup = False |  | ||||||
|         self._tooltip = False |  | ||||||
|         self._active = True |         self._active = True | ||||||
|         self._popup_anim = None |         self._palette = None | ||||||
|         self._enter_or_leave_sid = 0 |  | ||||||
|          |  | ||||||
|         hippo.CanvasBox.__init__(self, **kwargs) |  | ||||||
| 
 | 
 | ||||||
|         self.connect_after('motion-notify-event', self._motion_notify_event_cb) |         hippo.CanvasBox.__init__(self, **kwargs) | ||||||
| 
 | 
 | ||||||
|     def _clear_buffers(self): |     def _clear_buffers(self): | ||||||
|         cur_buf_key = self._get_current_buffer_key() |         cur_buf_key = self._get_current_buffer_key() | ||||||
| @ -233,8 +205,6 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem): | |||||||
|             self.emit_request_changed() |             self.emit_request_changed() | ||||||
|         elif pspec.name == 'cache': |         elif pspec.name == 'cache': | ||||||
|             self._cache = value |             self._cache = value | ||||||
|         elif pspec.name == 'tooltip': |  | ||||||
|             self._tooltip = value |  | ||||||
|         elif pspec.name == 'active': |         elif pspec.name == 'active': | ||||||
|             if self._active != value: |             if self._active != value: | ||||||
|                 if not self._cache: |                 if not self._cache: | ||||||
| @ -282,8 +252,6 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem): | |||||||
|             return self._stroke_color |             return self._stroke_color | ||||||
|         elif pspec.name == 'cache': |         elif pspec.name == 'cache': | ||||||
|             return self._cache |             return self._cache | ||||||
|         elif pspec.name == 'tooltip': |  | ||||||
|             return self._tooltip |  | ||||||
|         elif pspec.name == 'active': |         elif pspec.name == 'active': | ||||||
|             return self._active |             return self._active | ||||||
| 
 | 
 | ||||||
| @ -346,142 +314,24 @@ class CanvasIcon(hippo.CanvasBox, hippo.CanvasItem): | |||||||
|         self.emit_activated() |         self.emit_activated() | ||||||
|         return True |         return True | ||||||
| 
 | 
 | ||||||
|     def get_popup(self): |  | ||||||
|         if self._tooltip: |  | ||||||
|             tooltip_popup = Popup() |  | ||||||
|             text = hippo.CanvasText(text=self._tooltip) |  | ||||||
|             text.props.background_color = color.MENU_BACKGROUND.get_int() |  | ||||||
|             text.props.color = color.LABEL_TEXT.get_int() |  | ||||||
|             text.props.font_desc = font.DEFAULT.get_pango_desc() |  | ||||||
|             text.props.padding = units.points_to_pixels(5) |  | ||||||
|             tooltip_popup.append(text) |  | ||||||
|              |  | ||||||
|             return tooltip_popup |  | ||||||
|         else: |  | ||||||
|             return None |  | ||||||
| 
 |  | ||||||
|     def get_popup_context(self): |  | ||||||
|         return None |  | ||||||
| 
 |  | ||||||
|     def show_popup(self): |  | ||||||
|         if not self._popup: |  | ||||||
|             self._popup = self.get_popup() |  | ||||||
|             if not self._popup: |  | ||||||
|                 return |  | ||||||
| 
 |  | ||||||
|         if not self.get_context(): |  | ||||||
|             # If we have been detached from our parent, don't show up the popup |  | ||||||
|             # in this case. |  | ||||||
|             return |  | ||||||
| 
 |  | ||||||
|         popup_context = self.get_popup_context() |  | ||||||
|          |  | ||||||
|         [x, y] = [None, None] |  | ||||||
|         if popup_context: |  | ||||||
|             try: |  | ||||||
|                 [x, y] = popup_context.get_position(self, self._popup) |  | ||||||
|             except NotImplementedError: |  | ||||||
|                 pass |  | ||||||
| 
 |  | ||||||
|         if [x, y] == [None, None]: |  | ||||||
|             context = self.get_context() |  | ||||||
|             [x, y] = context.translate_to_screen(self) |  | ||||||
|          |  | ||||||
|             # TODO: Any better place to do this? |  | ||||||
|             [min_width, natural_width] = self.get_width_request() |  | ||||||
|             [pop_min_width, pop_natural_width] = self._popup.get_width_request() |  | ||||||
|             self._popup.props.box_width = max(pop_min_width, min_width) |  | ||||||
| 
 |  | ||||||
|             [width, height] = self.get_allocation() |  | ||||||
|             y += height |  | ||||||
|             position = [x, y] |  | ||||||
| 
 |  | ||||||
|         self._popup.popup(x, y) |  | ||||||
|         self._popup.connect('motion-notify-event', |  | ||||||
|                             self.popup_motion_notify_event_cb) |  | ||||||
|         self._popup.connect('action-completed', |  | ||||||
|                             self._popup_action_completed_cb) |  | ||||||
| 
 |  | ||||||
|         if popup_context: |  | ||||||
|             popup_context.popped_up(self._popup) |  | ||||||
| 
 |  | ||||||
|     def hide_popup(self): |  | ||||||
|         if self._popup: |  | ||||||
|             self._popup.popdown() |  | ||||||
| 
 |  | ||||||
|             popup_context = self.get_popup_context() |  | ||||||
|             if popup_context: |  | ||||||
|                 popup_context.popped_down(self._popup) |  | ||||||
| 
 |  | ||||||
|             self._popup = None |  | ||||||
| 
 |  | ||||||
|     def _enter(self): |  | ||||||
|         self._popup_anim = animator.Animator(0.2, 10) |  | ||||||
|         self._popup_anim.add(_PopupAnimation(self)) |  | ||||||
|         self._popup_anim.start() |  | ||||||
| 
 |  | ||||||
|         self.prelight(enter=True) |  | ||||||
| 
 |  | ||||||
|     def _leave(self): |  | ||||||
|         # FIXME: This is a hack for taking out the popdown delay for tooltips and |  | ||||||
|         # increasing the rest of rollovers. We need a better way for specifiying |  | ||||||
|         # different behaviors for the different kinds of popups. |  | ||||||
|         if type(self._popup) == Popup: |  | ||||||
|             self.hide_popup() |  | ||||||
|         else: |  | ||||||
|             self._popup_anim = animator.Animator(0.5, 10) |  | ||||||
|             self._popup_anim.add(_PopdownAnimation(self)) |  | ||||||
|             self._popup_anim.start() |  | ||||||
| 
 |  | ||||||
|         self.prelight(enter=False) |  | ||||||
| 
 |  | ||||||
|     def _enter_or_leave_cb(self): |  | ||||||
|         if self._popup_anim: |  | ||||||
|             self._popup_anim.stop() |  | ||||||
| 
 |  | ||||||
|         if self._hover_icon or self._hover_popup: |  | ||||||
|             self._enter() |  | ||||||
|         else: |  | ||||||
|             self._leave() |  | ||||||
| 
 |  | ||||||
|         self._enter_or_leave_sid = 0 |  | ||||||
| 
 |  | ||||||
|         return False |  | ||||||
| 
 |  | ||||||
|     def _schedule_enter_or_leave(self): |  | ||||||
|         if self._enter_or_leave_sid == 0: |  | ||||||
|             sid = gobject.idle_add(self._enter_or_leave_cb) |  | ||||||
|             self._enter_or_leave_sid = sid |  | ||||||
| 
 |  | ||||||
|     def _motion_notify_event_cb(self, button, event): |  | ||||||
|         if event.detail == hippo.MOTION_DETAIL_ENTER: |  | ||||||
|             self._hover_icon = True |  | ||||||
|         elif event.detail == hippo.MOTION_DETAIL_LEAVE: |  | ||||||
|             self._hover_icon = False |  | ||||||
| 
 |  | ||||||
|         self._schedule_enter_or_leave() |  | ||||||
| 
 |  | ||||||
|         return False |  | ||||||
| 
 |  | ||||||
|     def popup_motion_notify_event_cb(self, popup, event): |  | ||||||
|         if event.detail == hippo.MOTION_DETAIL_ENTER: |  | ||||||
|             self._hover_popup = True |  | ||||||
|         elif event.detail == hippo.MOTION_DETAIL_LEAVE: |  | ||||||
|             self._hover_popup = False |  | ||||||
| 
 |  | ||||||
|         self._schedule_enter_or_leave() |  | ||||||
| 
 |  | ||||||
|         return False |  | ||||||
| 
 |  | ||||||
|     def _popup_action_completed_cb(self, popup): |  | ||||||
|         self.hide_popup() |  | ||||||
| 
 |  | ||||||
|     def prelight(self, enter): |     def prelight(self, enter): | ||||||
|         """ |         """ | ||||||
|         Override this method for adding prelighting behavior. |         Override this method for adding prelighting behavior. | ||||||
|         """ |         """ | ||||||
|         pass |         pass | ||||||
| 
 | 
 | ||||||
|  |     def get_palette(self): | ||||||
|  |         return self._palette | ||||||
|  |      | ||||||
|  |     def set_palette(self, palette): | ||||||
|  |         self._palette = palette | ||||||
|  |         self._palette.props.invoker = CanvasInvoker(self) | ||||||
|  | 
 | ||||||
|  |     def set_tooltip(self, text): | ||||||
|  |         self.set_palette(Palette(text)) | ||||||
|  |      | ||||||
|  |     palette = property(get_palette, set_palette) | ||||||
|  | 
 | ||||||
| def get_icon_state(base_name, perc): | def get_icon_state(base_name, perc): | ||||||
|         step = 5 |         step = 5 | ||||||
|         strength = round(perc / step) * step |         strength = round(perc / step) * step | ||||||
|  | |||||||
| @ -15,6 +15,8 @@ | |||||||
| # 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 gtk | import gtk | ||||||
| import gobject | import gobject | ||||||
| import time | import time | ||||||
| @ -61,9 +63,9 @@ class Palette(gobject.GObject): | |||||||
| 
 | 
 | ||||||
|         self._menu = _sugarext.Menu() |         self._menu = _sugarext.Menu() | ||||||
| 
 | 
 | ||||||
|         primary = _PrimaryMenuItem(label, accel_path) |         self._primary = _PrimaryMenuItem(label, accel_path) | ||||||
|         self._menu.append(primary) |         self._menu.append(self._primary) | ||||||
|         primary.show() |         self._primary.show() | ||||||
| 
 | 
 | ||||||
|         self._separator = gtk.SeparatorMenuItem() |         self._separator = gtk.SeparatorMenuItem() | ||||||
|         self._menu.append(self._separator) |         self._menu.append(self._separator) | ||||||
| @ -81,6 +83,9 @@ class Palette(gobject.GObject): | |||||||
|         self._menu.connect('button-press-event', |         self._menu.connect('button-press-event', | ||||||
|                            self._button_press_event_cb) |                            self._button_press_event_cb) | ||||||
| 
 | 
 | ||||||
|  |     def set_primary_text(self, label, accel_path): | ||||||
|  |         self._primary.set_label(label, accel_path) | ||||||
|  | 
 | ||||||
|     def append_menu_item(self, item): |     def append_menu_item(self, item): | ||||||
|         self._separator.show() |         self._separator.show() | ||||||
|         self._menu.insert(item, len(self._menu.get_children()) - 2) |         self._menu.insert(item, len(self._menu.get_children()) - 2) | ||||||
| @ -152,8 +157,8 @@ class Palette(gobject.GObject): | |||||||
|         return x, y |         return x, y | ||||||
| 
 | 
 | ||||||
|     def _in_screen(self, x, y): |     def _in_screen(self, x, y): | ||||||
|         [width, height] = self._menu.get_size_request() |         [width, height] = self._menu.size_request() | ||||||
| 
 |          | ||||||
|         return x + width < gtk.gdk.screen_width() and \ |         return x + width < gtk.gdk.screen_width() and \ | ||||||
|                y + height < gtk.gdk.screen_height() and \ |                y + height < gtk.gdk.screen_height() and \ | ||||||
|                x >= 0 and y >= 0 |                x >= 0 and y >= 0 | ||||||
| @ -224,17 +229,23 @@ class Palette(gobject.GObject): | |||||||
| class _PrimaryMenuItem(gtk.MenuItem): | class _PrimaryMenuItem(gtk.MenuItem): | ||||||
|     def __init__(self, label, accel_path): |     def __init__(self, label, accel_path): | ||||||
|         gtk.MenuItem.__init__(self) |         gtk.MenuItem.__init__(self) | ||||||
|  |         self._set_label(label, accel_path) | ||||||
| 
 | 
 | ||||||
|         label = gtk.AccelLabel(label) |     def set_label(self, label, accel_path): | ||||||
|         label.set_accel_widget(self) |         self.remove(self._label) | ||||||
|  |         self._set_label(label, accel_path) | ||||||
|  | 
 | ||||||
|  |     def _set_label(self, label, accel_path): | ||||||
|  |         self._label = gtk.AccelLabel(label) | ||||||
|  |         self._label.set_accel_widget(self) | ||||||
| 
 | 
 | ||||||
|         if accel_path: |         if accel_path: | ||||||
|             self.set_accel_path(accel_path) |             self.set_accel_path(accel_path) | ||||||
|             label.set_alignment(0.0, 0.5) |             self._label.set_alignment(0.0, 0.5) | ||||||
| 
 |  | ||||||
|         self.add(label) |  | ||||||
|         label.show() |  | ||||||
| 
 | 
 | ||||||
|  |         self.add(self._label) | ||||||
|  |         self._label.show() | ||||||
|  |      | ||||||
| class _ContentMenuItem(gtk.MenuItem): | class _ContentMenuItem(gtk.MenuItem): | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         gtk.MenuItem.__init__(self) |         gtk.MenuItem.__init__(self) | ||||||
|  | |||||||
| @ -20,10 +20,9 @@ import gobject | |||||||
| import time | import time | ||||||
| 
 | 
 | ||||||
| from sugar.graphics.icon import Icon | from sugar.graphics.icon import Icon | ||||||
| from sugar.graphics.palette import * | from sugar.graphics.palette import Palette, WidgetInvoker | ||||||
| 
 | 
 | ||||||
| class ToolButton(gtk.ToolButton): | class ToolButton(gtk.ToolButton): | ||||||
|     _POPUP_PALETTE_DELAY = 100 |  | ||||||
| 
 | 
 | ||||||
|     def __init__(self, icon_name=None): |     def __init__(self, icon_name=None): | ||||||
|         gtk.ToolButton.__init__(self) |         gtk.ToolButton.__init__(self) | ||||||
| @ -43,7 +42,6 @@ class ToolButton(gtk.ToolButton): | |||||||
|         self._palette.props.invoker = WidgetInvoker(self.child) |         self._palette.props.invoker = WidgetInvoker(self.child) | ||||||
| 
 | 
 | ||||||
|     def set_tooltip(self, text): |     def set_tooltip(self, text): | ||||||
|         self._palette = Palette(text) |         self.set_palette(Palette(text)) | ||||||
|         self._palette.props.invoker = WidgetInvoker(self.child) |  | ||||||
|      |      | ||||||
|     palette = property(get_palette, set_palette) |     palette = property(get_palette, set_palette) | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Tomeu Vizoso
						Tomeu Vizoso