Palette: event improves
This commit is contained in:
parent
c35db7acf8
commit
b1ed24498c
@ -17,6 +17,7 @@
|
|||||||
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
import gtk
|
import gtk
|
||||||
|
from gtk import gdk, keysyms
|
||||||
import gobject
|
import gobject
|
||||||
import pango
|
import pango
|
||||||
|
|
||||||
@ -49,6 +50,7 @@ class Palette(gtk.Window):
|
|||||||
|
|
||||||
self._palette_label = gtk.Label()
|
self._palette_label = gtk.Label()
|
||||||
self._palette_label.set_ellipsize(pango.ELLIPSIZE_START)
|
self._palette_label.set_ellipsize(pango.ELLIPSIZE_START)
|
||||||
|
self._palette_label.show()
|
||||||
|
|
||||||
self._separator = gtk.HSeparator()
|
self._separator = gtk.HSeparator()
|
||||||
self._separator.hide()
|
self._separator.hide()
|
||||||
@ -58,7 +60,10 @@ class Palette(gtk.Window):
|
|||||||
self._menu_bar.show()
|
self._menu_bar.show()
|
||||||
|
|
||||||
self._content = gtk.HBox()
|
self._content = gtk.HBox()
|
||||||
|
self._content.show()
|
||||||
|
|
||||||
self._button_bar = gtk.HButtonBox()
|
self._button_bar = gtk.HButtonBox()
|
||||||
|
self._button_bar.show()
|
||||||
|
|
||||||
# Set main container
|
# Set main container
|
||||||
vbox = gtk.VBox(False, 0)
|
vbox = gtk.VBox(False, 0)
|
||||||
@ -69,11 +74,25 @@ class Palette(gtk.Window):
|
|||||||
vbox.pack_start(self._button_bar, True, True, self._PADDING)
|
vbox.pack_start(self._button_bar, True, True, self._PADDING)
|
||||||
vbox.show()
|
vbox.show()
|
||||||
|
|
||||||
# FIXME
|
# Widget events
|
||||||
self.connect('focus_out_event', self._close_palette)
|
self.connect('motion-notify-event', self._mouse_over_widget)
|
||||||
|
self.connect('leave-notify-event', self._mouse_out_widget)
|
||||||
|
self.connect('button-press-event', self._close_palette)
|
||||||
|
self.connect('key-press-event', self._on_key_press_event)
|
||||||
|
|
||||||
self.set_border_width(self._WIN_BORDER)
|
self.set_border_width(self._WIN_BORDER)
|
||||||
self.add(vbox)
|
self.add(vbox)
|
||||||
|
|
||||||
|
def _is_mouse_out(self, window, event):
|
||||||
|
# If we're clicking outside of the Palette
|
||||||
|
# return True
|
||||||
|
if (event.window != self.window or
|
||||||
|
(tuple(self.allocation.intersect(
|
||||||
|
gdk.Rectangle(x=int(event.x), y=int(event.y),
|
||||||
|
width=1, height=1)))) == (0, 0, 0, 0)):
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
def do_set_property(self, pspec, value):
|
def do_set_property(self, pspec, value):
|
||||||
|
|
||||||
@ -99,7 +118,7 @@ class Palette(gtk.Window):
|
|||||||
elif self._alignment == ALIGNMENT_BOTTOM_RIGHT:
|
elif self._alignment == ALIGNMENT_BOTTOM_RIGHT:
|
||||||
move_x = parent_rectangle.x - palette_width
|
move_x = parent_rectangle.x - palette_width
|
||||||
move_y = window_axis[1] + parent_rectangle.y + parent_rectangle.height
|
move_y = window_axis[1] + parent_rectangle.y + parent_rectangle.height
|
||||||
|
|
||||||
elif self._alignment == ALIGNMENT_LEFT_BOTTOM:
|
elif self._alignment == ALIGNMENT_LEFT_BOTTOM:
|
||||||
move_x = parent_rectangle.x - palette_width
|
move_x = parent_rectangle.x - palette_width
|
||||||
move_y = palette_rectangle.y
|
move_y = palette_rectangle.y
|
||||||
@ -126,8 +145,9 @@ class Palette(gtk.Window):
|
|||||||
|
|
||||||
self.move(move_x, move_y)
|
self.move(move_x, move_y)
|
||||||
|
|
||||||
def _close_palette(self, widget, event):
|
def _close_palette(self, widget=None, event=None):
|
||||||
self.destroy()
|
gtk.gdk.pointer_ungrab()
|
||||||
|
self.hide()
|
||||||
|
|
||||||
def set_primary_state(self, label, accel_path=None):
|
def set_primary_state(self, label, accel_path=None):
|
||||||
if accel_path != None:
|
if accel_path != None:
|
||||||
@ -148,9 +168,42 @@ class Palette(gtk.Window):
|
|||||||
widget.show()
|
widget.show()
|
||||||
|
|
||||||
def append_button(self, button):
|
def append_button(self, button):
|
||||||
|
button.connect('released', self._close_palette)
|
||||||
self._button_bar.pack_start(button, True, True, self._PADDING)
|
self._button_bar.pack_start(button, True, True, self._PADDING)
|
||||||
button.show()
|
button.show()
|
||||||
|
|
||||||
def display(self, button):
|
def display(self, button):
|
||||||
self.show()
|
self.show()
|
||||||
self.set_position()
|
self.set_position()
|
||||||
|
self._pointer_grab()
|
||||||
|
|
||||||
|
def _pointer_grab(self):
|
||||||
|
gtk.gdk.pointer_grab(self.window, owner_events=False,
|
||||||
|
event_mask=gtk.gdk.BUTTON_PRESS_MASK |
|
||||||
|
gtk.gdk.BUTTON_RELEASE_MASK |
|
||||||
|
gtk.gdk.ENTER_NOTIFY_MASK |
|
||||||
|
gtk.gdk.LEAVE_NOTIFY_MASK |
|
||||||
|
gtk.gdk.POINTER_MOTION_MASK)
|
||||||
|
|
||||||
|
gdk.keyboard_grab(self.window, False)
|
||||||
|
|
||||||
|
def _mouse_out_widget(self, widget, event):
|
||||||
|
if (widget == self) and self._is_mouse_out(widget, event):
|
||||||
|
self._pointer_grab()
|
||||||
|
|
||||||
|
def _mouse_over_widget(self, widget, event):
|
||||||
|
gtk.gdk.pointer_ungrab()
|
||||||
|
|
||||||
|
def _on_key_press_event(self, window, event):
|
||||||
|
|
||||||
|
# Escape or Alt+Up: Close
|
||||||
|
# Enter, Return or Space: Select
|
||||||
|
|
||||||
|
keyval = event.keyval
|
||||||
|
state = event.state & gtk.accelerator_get_default_mod_mask()
|
||||||
|
if (keyval == keysyms.Escape or
|
||||||
|
((keyval == keysyms.Up or keyval == keysyms.KP_Up) and
|
||||||
|
state == gdk.MOD1_MASK)):
|
||||||
|
self._close_palette()
|
||||||
|
elif keyval == keysyms.Tab:
|
||||||
|
self._close_palette()
|
||||||
|
@ -36,4 +36,5 @@ class ToolButton(gtk.ToolButton):
|
|||||||
palette.props.alignment = ALIGNMENT_BOTTOM_LEFT
|
palette.props.alignment = ALIGNMENT_BOTTOM_LEFT
|
||||||
|
|
||||||
def set_tooltip(self, text):
|
def set_tooltip(self, text):
|
||||||
pass
|
tp = gtk.Tooltips()
|
||||||
|
self.set_tooltip(tp, text, text)
|
||||||
|
Loading…
Reference in New Issue
Block a user