From 84fafd7a077a2383435c6668ce15559907df868f Mon Sep 17 00:00:00 2001 From: William Hua Date: Wed, 30 Oct 2013 17:22:26 -0700 Subject: Enable middle click and mouse wheel scrolling. --- lib/Makefile.am | 3 +-- lib/main.vala | 28 +++++++++++++++++++++++++++- 2 files changed, 28 insertions(+), 3 deletions(-) diff --git a/lib/Makefile.am b/lib/Makefile.am index fd8a945e..fc6eeb42 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -2,8 +2,7 @@ libexec_PROGRAMS = indicator-keyboard-service AM_CFLAGS = -w -DGNOME_DESKTOP_USE_UNSTABLE_API AM_LDFLAGS = -lm -AM_VALAFLAGS = --enable-experimental-non-null \ - --metadatadir $(top_srcdir)/deps \ +AM_VALAFLAGS = --metadatadir $(top_srcdir)/deps \ --vapidir $(top_srcdir)/deps indicator_keyboard_service_SOURCES = main.vala \ diff --git a/lib/main.vala b/lib/main.vala index 190276f8..53878989 100644 --- a/lib/main.vala +++ b/lib/main.vala @@ -568,6 +568,22 @@ public class Indicator.Keyboard.Service : Object { return (!) indicator_action; } + [DBus (visible = false)] + private void handle_middle_click (Variant? parameter) { + handle_scroll_wheel (new Variant.int32 (-1)); + } + + [DBus (visible = false)] + private void handle_scroll_wheel (Variant? parameter) { + if (parameter != null) { + var sources = source_settings.get_value ("sources"); + var current = source_settings.get_uint ("current"); + var length = (int) sources.n_children (); + + source_settings.set_uint ("current", (current + (length - parameter.get_int32 ())) % length); + } + } + [DBus (visible = false)] protected virtual SimpleActionGroup create_action_group (Action root_action) { var group = new SimpleActionGroup (); @@ -575,7 +591,15 @@ public class Indicator.Keyboard.Service : Object { group.insert (root_action); group.insert (source_settings.create_action ("current")); - var action = new SimpleAction ("map", null); + var action = new SimpleAction ("next", null); + action.activate.connect (handle_middle_click); + group.insert (action); + + action = new SimpleAction ("scroll", VariantType.INT32); + action.activate.connect (handle_scroll_wheel); + group.insert (action); + + action = new SimpleAction ("map", null); action.activate.connect (handle_activate_map); group.insert (action); @@ -653,6 +677,8 @@ public class Indicator.Keyboard.Service : Object { var indicator = new MenuItem.submenu ("x", submenu); indicator.set_attribute ("x-canonical-type", "s", "com.canonical.indicator.root"); + indicator.set_attribute ("x-canonical-secondary-action", "s", "indicator.next"); + indicator.set_attribute ("x-canonical-scroll-action", "s", "indicator.scroll"); indicator.set_detailed_action ("indicator.indicator"); menu.append_item (indicator); -- cgit v1.2.3 From c01d6f3fa3e8663da142f23b9e36dcf57622c57d Mon Sep 17 00:00:00 2001 From: William Hua Date: Mon, 4 Nov 2013 12:05:42 -0500 Subject: Be careful around large scrolling offsets. --- lib/main.vala | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/lib/main.vala b/lib/main.vala index 53878989..e9eb27b6 100644 --- a/lib/main.vala +++ b/lib/main.vala @@ -580,7 +580,10 @@ public class Indicator.Keyboard.Service : Object { var current = source_settings.get_uint ("current"); var length = (int) sources.n_children (); - source_settings.set_uint ("current", (current + (length - parameter.get_int32 ())) % length); + if (length > 0) { + var offset = parameter.get_int32 () % length; + source_settings.set_uint ("current", (current + (length - offset)) % length); + } } } -- cgit v1.2.3