[caribou] Make modifier keys toggle buttons.
- From: Eitan Isaacson <eitani src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [caribou] Make modifier keys toggle buttons.
- Date: Tue, 7 Dec 2010 16:36:28 +0000 (UTC)
commit 341f15b71e919430ac796898d928c0e98801df69
Author: Eitan Isaacson <eitan monotonous org>
Date: Tue Dec 7 08:32:11 2010 -0800
Make modifier keys toggle buttons.
caribou/ui/keyboard.py | 33 ++++++++++++++++++++++++++-------
1 files changed, 26 insertions(+), 7 deletions(-)
---
diff --git a/caribou/ui/keyboard.py b/caribou/ui/keyboard.py
index 0737a6f..1e6063e 100644
--- a/caribou/ui/keyboard.py
+++ b/caribou/ui/keyboard.py
@@ -178,11 +178,14 @@ class KeyboardPreferences:
font = fontbutton.get_font_name()
client.set_string(const.CARIBOU_GCONF + "/key_font", font)
-class Key(gtk.Button):
+class BaseKey(object):
+ '''An abstract class the represents a key on the keyboard.
+ Inheriting classes also need to inherit from gtk.Button or any
+ of it's subclasses.'''
def __init__(self, label = '', value = '', key_type = 'normal',
width = 1, fill = False):
- super(Key, self).__init__()
+
self.key_type = key_type
self.value = value
self.width = float(width)
@@ -265,6 +268,19 @@ class Key(gtk.Button):
value = property(_get_value, _set_value)
+
+class Key(gtk.Button, BaseKey):
+ def __init__(self, label = '', value = '', key_type = 'normal',
+ width = 1, fill = False):
+ gtk.Button.__init__(self)
+ BaseKey.__init__(self, label, value, key_type, width, fill)
+
+class ModifierKey(gtk.ToggleButton, BaseKey):
+ def __init__(self, label = '', value = '', key_type = 'normal',
+ width = 1, fill = False):
+ gtk.ToggleButton.__init__(self)
+ BaseKey.__init__(self, label, value, key_type, width, fill)
+
class KeyboardLayout(gtk.Alignment):
def __init__(self, name):
@@ -368,7 +384,10 @@ class KbLayoutDeserializer(object):
vars = {}
for key, value in key_vars.items():
vars[str(key)] = value
- key = Key(**vars)
+ if vars.get('key_type', '') == const.MASK_KEY_TYPE:
+ key = ModifierKey(**vars)
+ else:
+ key = Key(**vars)
keys.append(key)
return keys
@@ -447,8 +466,8 @@ class CaribouKeyboard(gtk.Notebook):
key.connect('clicked',
self._pressed_layout_switcher_key)
elif key.key_type == const.MASK_KEY_TYPE:
- key.connect('clicked',
- self._pressed_mask_key)
+ key.connect('toggled',
+ self._toggled_mask_key)
elif key.key_type == const.PREFERENCES_KEY_TYPE:
key.connect('clicked',
self._pressed_preferences_key)
@@ -502,8 +521,8 @@ class CaribouKeyboard(gtk.Notebook):
def _pressed_layout_switcher_key(self, key):
self._switch_to_layout(key.value)
- def _pressed_mask_key(self, key):
- if self.current_mask & key.value != 0:
+ def _toggled_mask_key(self, key):
+ if not key.get_active():
self.vk.unlatch_mod(key.value)
self.current_mask &= ~key.value
else:
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]