From 8be813c2d21face2f13191c44245cde34ffb9a4f Mon Sep 17 00:00:00 2001 From: Marko Lindqvist Date: Sun, 22 Jan 2023 17:27:38 +0200 Subject: [PATCH 30/30] gtk3(.22): Add volume control key bindings See osdn #46589 Signed-off-by: Marko Lindqvist --- client/gui-gtk-3.0/gui_main.c | 39 ++++++++++++++++++++++++++-------- client/gui-gtk-3.22/gui_main.c | 39 ++++++++++++++++++++++++++-------- data/helpdata.txt | 1 + 3 files changed, 61 insertions(+), 18 deletions(-) diff --git a/client/gui-gtk-3.0/gui_main.c b/client/gui-gtk-3.0/gui_main.c index c57e5e162d..f105155ca5 100644 --- a/client/gui-gtk-3.0/gui_main.c +++ b/client/gui-gtk-3.0/gui_main.c @@ -448,7 +448,35 @@ static gboolean key_press_map_canvas(GtkWidget *w, GdkEventKey *ev, } } - if (!(ev->state & GDK_CONTROL_MASK)) { + if (ev->state & GDK_SHIFT_MASK) { + bool volchange = FALSE; + + switch (ev->keyval) { + case GDK_KEY_plus: + case GDK_KEY_KP_Add: + gui_options.sound_effects_volume += 10; + volchange = TRUE; + break; + + case GDK_KEY_minus: + case GDK_KEY_KP_Subtract: + gui_options.sound_effects_volume -= 10; + volchange = TRUE; + break; + + default: + break; + } + + if (volchange) { + struct option *poption = optset_option_by_name(client_optset, "sound_effects_volume"); + + gui_options.sound_effects_volume = CLIP(0, gui_options.sound_effects_volume, 100); + option_changed(poption); + + return TRUE; + } + } else if (!(ev->state & GDK_CONTROL_MASK)) { switch (ev->keyval) { case GDK_KEY_plus: case GDK_KEY_KP_Add: @@ -580,9 +608,7 @@ static gboolean toplevel_key_press_handler(GtkWidget *w, GdkEventKey *ev, return FALSE; } - switch (ev->keyval) { - - case GDK_KEY_apostrophe: + if (ev->keyval == GDK_KEY_apostrophe) { /* Allow this even if not in main map view; chatline is present on * some other pages too */ @@ -604,12 +630,7 @@ static gboolean toplevel_key_press_handler(GtkWidget *w, GdkEventKey *ev, if (inputline_is_visible()) { inputline_grab_focus(); return TRUE; - } else { - break; } - - default: - break; } if (!gtk_widget_get_mapped(top_vbox) diff --git a/client/gui-gtk-3.22/gui_main.c b/client/gui-gtk-3.22/gui_main.c index 9d860d9f13..3609404a0c 100644 --- a/client/gui-gtk-3.22/gui_main.c +++ b/client/gui-gtk-3.22/gui_main.c @@ -429,7 +429,35 @@ static gboolean key_press_map_canvas(GtkWidget *w, GdkEventKey *ev, } } - if (!(ev->state & GDK_CONTROL_MASK)) { + if (ev->state & GDK_SHIFT_MASK) { + bool volchange = FALSE; + + switch (ev->keyval) { + case GDK_KEY_plus: + case GDK_KEY_KP_Add: + gui_options.sound_effects_volume += 10; + volchange = TRUE; + break; + + case GDK_KEY_minus: + case GDK_KEY_KP_Subtract: + gui_options.sound_effects_volume -= 10; + volchange = TRUE; + break; + + default: + break; + } + + if (volchange) { + struct option *poption = optset_option_by_name(client_optset, "sound_effects_volume"); + + gui_options.sound_effects_volume = CLIP(0, gui_options.sound_effects_volume, 100); + option_changed(poption); + + return TRUE; + } + } else if (!(ev->state & GDK_CONTROL_MASK)) { switch (ev->keyval) { case GDK_KEY_plus: case GDK_KEY_KP_Add: @@ -561,9 +589,7 @@ static gboolean toplevel_key_press_handler(GtkWidget *w, GdkEventKey *ev, return FALSE; } - switch (ev->keyval) { - - case GDK_KEY_apostrophe: + if (ev->keyval == GDK_KEY_apostrophe) { /* Allow this even if not in main map view; chatline is present on * some other pages too */ @@ -585,12 +611,7 @@ static gboolean toplevel_key_press_handler(GtkWidget *w, GdkEventKey *ev, if (inputline_is_visible()) { inputline_grab_focus(); return TRUE; - } else { - break; } - - default: - break; } if (!gtk_widget_get_mapped(top_vbox) diff --git a/data/helpdata.txt b/data/helpdata.txt index 145a996d44..8f62c2097b 100644 --- a/data/helpdata.txt +++ b/data/helpdata.txt @@ -1704,6 +1704,7 @@ Unit Movement:\n\ Main Map (Keys):\n\ ================\n\ Some clients support zooming/scaling the map graphics with the + and - keys.\n\ + Some clients support audio volume control with Shift-+ and Shift-- keys.\n\ c: (c)enter view on active unit\n\ Shift-home: center view on capital\n\ Shift-arrows: scroll map\n\ -- 2.39.0