diff options
Diffstat (limited to 'common1/Util/KeyboardWindow.py')
-rw-r--r-- | common1/Util/KeyboardWindow.py | 180 |
1 files changed, 0 insertions, 180 deletions
diff --git a/common1/Util/KeyboardWindow.py b/common1/Util/KeyboardWindow.py deleted file mode 100644 index e828967..0000000 --- a/common1/Util/KeyboardWindow.py +++ /dev/null @@ -1,180 +0,0 @@ -import pygtk -pygtk.require( '2.0' ) -import gtk -import random -from common.Util.ThemeWidgets import keyButton -import common.Config as Config -KEY_MAP_PIANO = Config.KEY_MAP_PIANO - -class KeyboardWindow(gtk.Window): - def __init__(self, size = None, pos = 0, popup = False): - if popup is False: - gtk.Window.__init__(self , gtk.WINDOW_TOPLEVEL) - else: - gtk.Window.__init__(self , gtk.WINDOW_POPUP) - color = gtk.gdk.color_parse("#000000") - self.modify_bg(gtk.STATE_NORMAL, color) - self.set_decorated(False) - - self.add_events(gtk.gdk.BUTTON_PRESS_MASK | gtk.gdk.BUTTON_RELEASE_MASK | gtk.gdk.ENTER_NOTIFY_MASK | gtk.gdk.KEY_PRESS_MASK) - self.connect("key-press-event",self.handle_keypress) - self.connect("key-release-event",self.handle_keyrelease) - self.connect("button-press-event",self.handle_mousePress) - self.connect("button-release-event",self.handle_mouseRelease) - self.connect("enter-notify-event",self.handle_enter) - - self.size = size - self.pos = pos - self.popup = popup - self.set_pos(self.pos) - - if self.size == None: - self.pixel_space = 15 - self.height = 45 - else: - self.pixel_space = size - self.height = 3 * size - - self.draw() - - def draw(self): - self.rows = {} - self.rows[1] = [(49,1), (10,3), (11,3), (12,3), (13,3), (14,3), (15,3), (16,3), (17,3), (18,3), (19,3), (20,3), (21,5)] - self.rows[2] = [(23,3), (24,3), (25,3), (26,3), (27,3), (28,3), (29,3), (30,3), (31,3), (32,3), (33,3), (34,3), (35,4)] - self.rows[3] = [(37,4), (38,3), (39,3), (40,3), (41,3), (42,3), (43,3), (44,3), (45,3), (46,3), (47,3), (48,3), (51,3)] - self.rows[4] = [(50,6), (52,3), (53,3), (54,3), (55,3), (56,3), (57,3), (58,3), (59,3), (60,3), (61,3), (62,5)] - self.rows[5] = [(216,1),(133,4),(64,4), (65,25), (108,4), (134,4,), (113,3)] - - self.right_section = [(22,7),(36,(7,7)),(111,3),(219,3),(116,3),(114,3)] - - self.btn_dic = {} - - mainvbox = gtk.VBox() - mainhbox = gtk.HBox() - - #Main keyboard section - vbox = gtk.VBox() - for row in [1,2,3,4,5]: - hbox = gtk.HBox() - for key in self.rows[row]: - self.btn_dic[key[0]] = keyButton(self.pixel_space * key[1], self.height, [0,0,0], [0.5,0.5,0.5]) - hbox.pack_start(self.btn_dic[key[0]], padding = self.pixel_space//2) - vbox.pack_start(hbox, padding = self.pixel_space//2) - mainhbox.pack_start(vbox) - - #Right part of the keyboard - right_vbox = gtk.VBox() - right_tophbox = gtk.HBox() - right_lowhbox = gtk.HBox() - - self.btn_dic[self.right_section[0][0]] = keyButton(self.pixel_space * self.right_section[0][1], self.height, [0,0,0], [0.5,0.5,0.5]) - self.btn_dic[self.right_section[1][0]] = keyButton(self.pixel_space * self.right_section[1][1][0], self.pixel_space * self.right_section[1][1][1], [0,0,0], [0.5,0.5,0.5]) - self.btn_dic[self.right_section[2][0]] = keyButton(self.pixel_space * self.right_section[2][1], self.height, [0,0,0], [0.5,0.5,0.5]) - self.btn_dic[self.right_section[3][0]] = keyButton(self.pixel_space * self.right_section[3][1], self.height, [0,0,0], [0.5,0.5,0.5]) - self.btn_dic[self.right_section[4][0]] = keyButton(self.pixel_space * self.right_section[4][1], self.height, [0,0,0], [0.5,0.5,0.5]) - self.btn_dic[self.right_section[5][0]] = keyButton(self.pixel_space * self.right_section[5][1], self.height, [0,0,0], [0.5,0.5,0.5]) - - right_vbox.pack_start(self.btn_dic[self.right_section[0][0]], padding = self.pixel_space//2) - right_vbox.pack_start(self.btn_dic[self.right_section[1][0]], padding = self.pixel_space//2) - right_tophbox.pack_start(self.btn_dic[self.right_section[2][0]], padding = self.pixel_space//2) - right_tophbox.pack_start(self.btn_dic[self.right_section[3][0]], padding = self.pixel_space//2) - right_lowhbox.pack_start(self.btn_dic[self.right_section[4][0]], padding = self.pixel_space//2) - right_lowhbox.pack_start(self.btn_dic[self.right_section[5][0]], padding = self.pixel_space//2) - right_vbox.pack_start(right_tophbox, padding = self.pixel_space//2) - right_vbox.pack_start(right_lowhbox, padding = self.pixel_space//2) - - #Mouse buttons - mouse_hbox = gtk.HBox() - self.btn_dic["left_mouse"] = keyButton(self.pixel_space * 6, self.pixel_space * 2, [0,0,0], [0.5,0.5,0.5]) - self.btn_dic["right_mouse"] = keyButton(self.pixel_space * 6, self.pixel_space * 2, [0,0,0], [0.5,0.5,0.5]) - mouse_hbox.pack_start(self.btn_dic["left_mouse"], True, True, self.pixel_space//2) - mouse_hbox.pack_end(self.btn_dic["right_mouse"], True, True, self.pixel_space//2) - - - #Enter and Leave connections - for key in self.btn_dic: - self.btn_dic[key].connect("enter",self.handle_mouseEnter) - self.btn_dic[key].connect("leave",self.handle_mouseLeave) - - mainhbox.pack_start(right_vbox) - mainvbox.pack_start(mainhbox) - mainvbox.pack_start(mouse_hbox, padding = self.pixel_space//2) - - self.add(mainvbox) - - def set_pos(self,_pos = 0): - width = self.get_screen().get_width() - height = self.get_screen().get_height() - win_width = self.get_size()[0] - win_height = self.get_size()[1] - - self.pos = _pos - - pos = [0,0] - pos[0] = (0, 0) - pos[1] = (width - win_width, height - win_height) - self.move(pos[self.pos][0],pos[self.pos][1]) - - def color_piano(self): - for key in KEY_MAP_PIANO: - self.btn_dic[key].set_fillcolor(1,1,1) - - - def handle_keypress(self,widget,event): - if event.hardware_keycode == 9: # Hide the keyboard with escape Key - self.hide_all() - elif event.hardware_keycode == 216: # Send a fake mouse event - self.btn_dic["left_mouse"].set_fillcolor(random.random(),random.random(),random.random()) - elif event.hardware_keycode == 133: # Send a fake mouse event - self.btn_dic["right_mouse"].set_fillcolor(random.random(),random.random(),random.random()) - else: - if self.btn_dic.has_key(event.hardware_keycode): - self.btn_dic[event.hardware_keycode].set_fillcolor(random.random(),random.random(),random.random()) - - def handle_keyrelease(self,widget,event): - if KEY_MAP_PIANO.has_key(event.hardware_keycode): - self.btn_dic[event.hardware_keycode].set_fillcolor(1,1,1) - else: - if self.btn_dic.has_key(event.hardware_keycode): - self.btn_dic[event.hardware_keycode].set_fillcolor(0,0,0) - if event.hardware_keycode == 216 or event.hardware_keycode == 133: - self.btn_dic["left_mouse"].set_fillcolor(0,0,0) - self.btn_dic["right_mouse"].set_fillcolor(0,0,0) - - - def handle_mousePress(self,widget,event): - if event.button == 1: - self.btn_dic["left_mouse"].set_fillcolor(random.random(),random.random(),random.random()) - elif event.button == 3: - self.btn_dic["right_mouse"].set_fillcolor(random.random(),random.random(),random.random()) - - def handle_mouseRelease(self,widget,event): - if event.button == 1: - self.btn_dic["left_mouse"].set_fillcolor(0,0,0) - elif event.button == 3: - self.btn_dic["right_mouse"].set_fillcolor(0,0,0) - - def handle_mouseEnter(self,widget,event = None): - widget.set_strokecolor(1,1,1) - - def handle_mouseLeave(self,widget,event = None): - widget.set_strokecolor(0.5,0.5,0.5) - - def handle_enter(self,widget,event): - if self.popup is False: - return - if self.pos == 0: - self.set_pos(1) - else: - self.set_pos(0) - - def close(self,widget,event = None): - self.hide_all() - - - -if __name__ == "__main__": - win = KeyboardWindow() - win.connect("destroy",gtk.main_quit) - win.show_all() - gtk.main() |