shortcutcontroller: Introduce

This is a very barebones controller that currently does nothing but
activate the binding signals. Yay.

And because we have bindings on every widget (Yes, a GtkGrid has a
keybinding - 2 in fact), we need that controller everywhere.
This commit is contained in:
Benjamin Otte 2018-07-30 06:02:20 +02:00 committed by Matthias Clasen
parent 06660874ee
commit 5c6be5c0cd
8 changed files with 172 additions and 5 deletions

View File

@ -336,6 +336,7 @@
<xi:include href="xml/gtkgesturezoom.xml" /> <xi:include href="xml/gtkgesturezoom.xml" />
<xi:include href="xml/gtkgesturestylus.xml" /> <xi:include href="xml/gtkgesturestylus.xml" />
<xi:include href="xml/gtkpadcontroller.xml" /> <xi:include href="xml/gtkpadcontroller.xml" />
<xi:include href="xml/gtkshortcutcontroller.xml" />
</chapter> </chapter>
<chapter> <chapter>

View File

@ -6062,6 +6062,24 @@ GTK_EVENT_CONTROLLER_MOTION_GET_CLASS
gtk_event_controller_motion_get_type gtk_event_controller_motion_get_type
</SECTION> </SECTION>
<SECTION>
<FILE>gtkshortcutcontroller</FILE>
<TITLE>GtkShortcutController</TITLE>
GtkShortcutController
gtk_shortcut_controller_new
<SUBSECTION Standard>
GTK_TYPE_SHORTCUT_CONTROLLER
GTK_SHORTCUT_CONTROLLER
GTK_SHORTCUT_CONTROLLER_CLASS
GTK_IS_SHORTCUT_CONTROLLER
GTK_IS_SHORTCUT_CONTROLLER_CLASS
GTK_SHORTCUT_CONTROLLER_GET_CLASS
<SUBSECTION Private>
gtk_shortcut_controller_get_type
</SECTION>
<SECTION> <SECTION>
<FILE>gtkeventcontrollerkey</FILE> <FILE>gtkeventcontrollerkey</FILE>
<TITLE>GtkEventControllerKey</TITLE> <TITLE>GtkEventControllerKey</TITLE>

View File

@ -165,6 +165,7 @@ gtk_search_entry_get_type
gtk_selection_model_get_type gtk_selection_model_get_type
gtk_separator_get_type gtk_separator_get_type
gtk_settings_get_type gtk_settings_get_type
gtk_shortcut_controller_get_type
gtk_shortcut_label_get_type gtk_shortcut_label_get_type
gtk_shortcuts_window_get_type gtk_shortcuts_window_get_type
gtk_shortcuts_section_get_type gtk_shortcuts_section_get_type

View File

@ -198,6 +198,7 @@
#include <gtk/gtkselectionmodel.h> #include <gtk/gtkselectionmodel.h>
#include <gtk/gtkseparator.h> #include <gtk/gtkseparator.h>
#include <gtk/gtksettings.h> #include <gtk/gtksettings.h>
#include <gtk/gtkshortcutcontroller.h>
#include <gtk/gtkshortcutlabel.h> #include <gtk/gtkshortcutlabel.h>
#include <gtk/gtkshortcutsgroup.h> #include <gtk/gtkshortcutsgroup.h>
#include <gtk/gtkshortcutssection.h> #include <gtk/gtkshortcutssection.h>

View File

@ -0,0 +1,96 @@
/*
* Copyright © 2018 Benjamin Otte
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
* Authors: Benjamin Otte <otte@gnome.org>
*/
/**
* SECTION:gtkshortcutcontroller
* @Short_description: Event controller for shortcuts
* @Title: GtkShortcutController
* @See_also: #GtkEventController, #GtkShortcut
*
* #GtkShortcutController is an event controller that manages shortcuts.
**/
#include "config.h"
#include "gtkshortcutcontroller.h"
#include "gtkeventcontrollerprivate.h"
#include "gtkbindings.h"
#include <gdk/gdk.h>
struct _GtkShortcutController
{
GtkEventController parent_instance;
};
struct _GtkShortcutControllerClass
{
GtkEventControllerClass parent_class;
};
G_DEFINE_TYPE (GtkShortcutController, gtk_shortcut_controller,
GTK_TYPE_EVENT_CONTROLLER)
static void
gtk_shortcut_controller_finalize (GObject *object)
{
//GtkShortcutController *self = GTK_SHORTCUT_CONTROLLER (object);
G_OBJECT_CLASS (gtk_shortcut_controller_parent_class)->finalize (object);
}
static gboolean
gtk_shortcut_controller_handle_event (GtkEventController *controller,
GdkEvent *event,
double x,
double y)
{
GdkEventType event_type = gdk_event_get_event_type (event);
if (event_type == GDK_KEY_PRESS ||
event_type == GDK_KEY_RELEASE)
return gtk_bindings_activate_event (G_OBJECT (gtk_event_controller_get_widget (controller)),
event);
return FALSE;
}
static void
gtk_shortcut_controller_class_init (GtkShortcutControllerClass *klass)
{
GtkEventControllerClass *controller_class = GTK_EVENT_CONTROLLER_CLASS (klass);
GObjectClass *object_class = G_OBJECT_CLASS (klass);
object_class->finalize = gtk_shortcut_controller_finalize;
controller_class->handle_event = gtk_shortcut_controller_handle_event;
}
static void
gtk_shortcut_controller_init (GtkShortcutController *controller)
{
}
GtkEventController *
gtk_shortcut_controller_new (void)
{
return g_object_new (GTK_TYPE_SHORTCUT_CONTROLLER,
NULL);
}

View File

@ -0,0 +1,50 @@
/*
* Copyright © 2018 Benjamin Otte
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
*
* Authors: Benjamin Otte <otte@gnome.org>
*/
#ifndef __GTK_SHORTCUT_CONTROLLER_H__
#define __GTK_SHORTCUT_CONTROLLER_H__
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
#error "Only <gtk/gtk.h> can be included directly."
#endif
#include <gtk/gtkeventcontroller.h>
G_BEGIN_DECLS
#define GTK_TYPE_SHORTCUT_CONTROLLER (gtk_shortcut_controller_get_type ())
#define GTK_SHORTCUT_CONTROLLER(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_SHORTCUT_CONTROLLER, GtkShortcutController))
#define GTK_SHORTCUT_CONTROLLER_CLASS(k) (G_TYPE_CHECK_CLASS_CAST ((k), GTK_TYPE_SHORTCUT_CONTROLLER, GtkShortcutControllerClass))
#define GTK_IS_SHORTCUT_CONTROLLER(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_SHORTCUT_CONTROLLER))
#define GTK_IS_SHORTCUT_CONTROLLER_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), GTK_TYPE_SHORTCUT_CONTROLLER))
#define GTK_SHORTCUT_CONTROLLER_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GTK_TYPE_SHORTCUT_CONTROLLER, GtkShortcutControllerClass))
typedef struct _GtkShortcutController GtkShortcutController;
typedef struct _GtkShortcutControllerClass GtkShortcutControllerClass;
GDK_AVAILABLE_IN_ALL
GType gtk_shortcut_controller_get_type (void) G_GNUC_CONST;
GDK_AVAILABLE_IN_ALL
GtkEventController * gtk_shortcut_controller_new (void);
G_END_DECLS
#endif /* __GTK_SHORTCUT_CONTROLLER_H__ */

View File

@ -59,6 +59,7 @@
#include "gtknativeprivate.h" #include "gtknativeprivate.h"
#include "gtkscrollable.h" #include "gtkscrollable.h"
#include "gtksettingsprivate.h" #include "gtksettingsprivate.h"
#include "gtkshortcutcontroller.h"
#include "gtksizegroup-private.h" #include "gtksizegroup-private.h"
#include "gtksnapshotprivate.h" #include "gtksnapshotprivate.h"
#include "gtkstylecontextprivate.h" #include "gtkstylecontextprivate.h"
@ -2419,6 +2420,8 @@ gtk_widget_init (GTypeInstance *instance, gpointer g_class)
layout_manager_type = gtk_widget_class_get_layout_manager_type (g_class); layout_manager_type = gtk_widget_class_get_layout_manager_type (g_class);
if (layout_manager_type != G_TYPE_INVALID) if (layout_manager_type != G_TYPE_INVALID)
gtk_widget_set_layout_manager (widget, g_object_new (layout_manager_type, NULL)); gtk_widget_set_layout_manager (widget, g_object_new (layout_manager_type, NULL));
gtk_widget_add_controller (widget, gtk_shortcut_controller_new ());
} }
/** /**
@ -4910,11 +4913,6 @@ gtk_widget_event (GtkWidget *widget,
if (return_val == FALSE) if (return_val == FALSE)
return_val |= gtk_widget_run_controllers (widget, event, target, x, y, GTK_PHASE_BUBBLE); return_val |= gtk_widget_run_controllers (widget, event, target, x, y, GTK_PHASE_BUBBLE);
if (return_val == FALSE &&
(gdk_event_get_event_type (event) == GDK_KEY_PRESS ||
gdk_event_get_event_type (event) == GDK_KEY_RELEASE))
return_val |= gtk_bindings_activate_event (G_OBJECT (widget), event);
return return_val; return return_val;
} }

View File

@ -331,6 +331,7 @@ gtk_public_sources = files([
'gtkselectionmodel.c', 'gtkselectionmodel.c',
'gtkseparator.c', 'gtkseparator.c',
'gtksettings.c', 'gtksettings.c',
'gtkshortcutcontroller.c',
'gtkshortcutlabel.c', 'gtkshortcutlabel.c',
'gtkshortcutsgroup.c', 'gtkshortcutsgroup.c',
'gtkshortcutssection.c', 'gtkshortcutssection.c',
@ -568,6 +569,7 @@ gtk_public_headers = files([
'gtkselectionmodel.h', 'gtkselectionmodel.h',
'gtkseparator.h', 'gtkseparator.h',
'gtksettings.h', 'gtksettings.h',
'gtkshortcutcontroller.h',
'gtkshortcutlabel.h', 'gtkshortcutlabel.h',
'gtkshortcutsgroup.h', 'gtkshortcutsgroup.h',
'gtkshortcutssection.h', 'gtkshortcutssection.h',