[gnome-games/wip/exalm/views: 17/19] display-view: Handle key events
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-games/wip/exalm/views: 17/19] display-view: Handle key events
- Date: Mon, 25 Feb 2019 09:24:24 +0000 (UTC)
commit adf1ab447995e2ed9ea175021ca9bf5bd66ca5e4
Author: Alexander Mikhaylenko <exalm7659 gmail com>
Date: Thu Oct 4 21:51:26 2018 +0500
display-view: Handle key events
src/ui/application-window.vala | 45 +-----------------------------------------
src/ui/display-view.vala | 37 ++++++++++++++++++++++++++++++++++
2 files changed, 38 insertions(+), 44 deletions(-)
---
diff --git a/src/ui/application-window.vala b/src/ui/application-window.vala
index 37dfeb43..b4974843 100644
--- a/src/ui/application-window.vala
+++ b/src/ui/application-window.vala
@@ -204,10 +204,7 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
return true;
}
- if (current_view == collection_view)
- return current_view.on_key_pressed (event);
-
- return handle_display_key_event (event);
+ return current_view.on_key_pressed (event);
}
[GtkCallback]
@@ -575,46 +572,6 @@ private class Games.ApplicationWindow : Gtk.ApplicationWindow {
return true;
}
- private bool handle_display_key_event (Gdk.EventKey event) {
- if (current_view != display_view)
- return false;
-
- var default_modifiers = Gtk.accelerator_get_default_mod_mask ();
-
- if ((event.keyval == Gdk.Key.f || event.keyval == Gdk.Key.F) &&
- (event.state & default_modifiers) == Gdk.ModifierType.CONTROL_MASK &&
- display_view.header_bar.can_fullscreen) {
- is_fullscreen = !is_fullscreen;
- settings.set_boolean ("fullscreen", is_fullscreen);
-
- return true;
- }
-
- if (event.keyval == Gdk.Key.F11 && display_view.header_bar.can_fullscreen) {
- is_fullscreen = !is_fullscreen;
- settings.set_boolean ("fullscreen", is_fullscreen);
-
- return true;
- }
-
- if (event.keyval == Gdk.Key.Escape && display_view.header_bar.can_fullscreen) {
- is_fullscreen = false;
- settings.set_boolean ("fullscreen", false);
-
- return true;
- }
-
- if (((event.state & default_modifiers) == Gdk.ModifierType.MOD1_MASK) &&
- (((get_direction () == Gtk.TextDirection.LTR) && event.keyval == Gdk.Key.Left) ||
- ((get_direction () == Gtk.TextDirection.RTL) && event.keyval == Gdk.Key.Right))) {
- on_display_back ();
-
- return true;
- }
-
- return false;
- }
-
private void inhibit (Gtk.ApplicationInhibitFlags flags) {
if ((inhibit_flags & flags) == flags)
return;
diff --git a/src/ui/display-view.vala b/src/ui/display-view.vala
index e5e80409..3c39047c 100644
--- a/src/ui/display-view.vala
+++ b/src/ui/display-view.vala
@@ -38,6 +38,8 @@ private class Games.DisplayView: Object, UiView {
public bool is_fullscreen { get; set; }
+ private Settings settings;
+
private Binding box_fullscreen_binding;
private Binding header_bar_fullscreen_binding;
@@ -52,6 +54,8 @@ private class Games.DisplayView: Object, UiView {
box.back.connect (on_display_back);
header_bar.back.connect (on_display_back);
+ settings = new Settings ("org.gnome.Games");
+
box_fullscreen_binding = bind_property ("is-fullscreen", box, "is-fullscreen",
BindingFlags.BIDIRECTIONAL);
header_bar_fullscreen_binding = bind_property ("is-fullscreen", header_bar,
@@ -70,6 +74,39 @@ private class Games.DisplayView: Object, UiView {
}
public bool on_key_pressed (Gdk.EventKey event) {
+ var default_modifiers = Gtk.accelerator_get_default_mod_mask ();
+
+ if ((event.keyval == Gdk.Key.f || event.keyval == Gdk.Key.F) &&
+ (event.state & default_modifiers) == Gdk.ModifierType.CONTROL_MASK &&
+ header_bar.can_fullscreen) {
+ is_fullscreen = !is_fullscreen;
+ settings.set_boolean ("fullscreen", is_fullscreen);
+
+ return true;
+ }
+
+ if (event.keyval == Gdk.Key.F11 && header_bar.can_fullscreen) {
+ is_fullscreen = !is_fullscreen;
+ settings.set_boolean ("fullscreen", is_fullscreen);
+
+ return true;
+ }
+
+ if (event.keyval == Gdk.Key.Escape && header_bar.can_fullscreen) {
+ is_fullscreen = false;
+ settings.set_boolean ("fullscreen", false);
+
+ return true;
+ }
+
+ if (((event.state & default_modifiers) == Gdk.ModifierType.MOD1_MASK) &&
+ (((window.get_direction () == Gtk.TextDirection.LTR) && event.keyval == Gdk.Key.Left) ||
+ ((window.get_direction () == Gtk.TextDirection.RTL) && event.keyval == Gdk.Key.Right))) {
+ on_display_back ();
+
+ return true;
+ }
+
return false;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]