about dialog: Stop using ::key-press-event

Use a key event controller instead.
This commit is contained in:
Matthias Clasen 2018-02-07 19:17:11 -05:00 committed by Carlos Garnacho
parent 21d1ab42d1
commit 4990842981
2 changed files with 20 additions and 11 deletions

View File

@ -60,6 +60,7 @@
#include "gtkintl.h" #include "gtkintl.h"
#include "gtkdialogprivate.h" #include "gtkdialogprivate.h"
#include "gtkeventcontrollermotion.h" #include "gtkeventcontrollermotion.h"
#include "gtkeventcontrollerkey.h"
#include "gtkgesturemultipress.h" #include "gtkgesturemultipress.h"
@ -188,6 +189,8 @@ struct _GtkAboutDialogPrivate
GtkGesture *system_press; GtkGesture *system_press;
GtkEventController *license_motion; GtkEventController *license_motion;
GtkEventController *system_motion; GtkEventController *system_motion;
GtkEventController *license_key;
GtkEventController *system_key;
GtkLicense license_type; GtkLicense license_type;
@ -244,8 +247,10 @@ static gboolean gtk_about_dialog_activate_link (GtkAboutDialog
const gchar *uri); const gchar *uri);
static gboolean emit_activate_link (GtkAboutDialog *about, static gboolean emit_activate_link (GtkAboutDialog *about,
const gchar *uri); const gchar *uri);
static gboolean text_view_key_press_event (GtkWidget *text_view, static gboolean text_view_key_pressed (GtkEventController *controller,
GdkEventKey *event, guint keyval,
guint keycode,
GdkModifierType state,
GtkAboutDialog *about); GtkAboutDialog *about);
static void text_view_released (GtkGestureMultiPress *press, static void text_view_released (GtkGestureMultiPress *press,
int n, int n,
@ -609,7 +614,6 @@ gtk_about_dialog_class_init (GtkAboutDialogClass *klass)
gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, system_view); gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, system_view);
gtk_widget_class_bind_template_callback (widget_class, emit_activate_link); gtk_widget_class_bind_template_callback (widget_class, emit_activate_link);
gtk_widget_class_bind_template_callback (widget_class, text_view_key_press_event);
gtk_widget_class_bind_template_callback (widget_class, stack_visible_child_notify); gtk_widget_class_bind_template_callback (widget_class, stack_visible_child_notify);
} }
@ -781,6 +785,10 @@ gtk_about_dialog_init (GtkAboutDialog *about)
g_signal_connect (priv->license_motion, "motion", G_CALLBACK (text_view_motion), about); g_signal_connect (priv->license_motion, "motion", G_CALLBACK (text_view_motion), about);
priv->system_motion = gtk_event_controller_motion_new (priv->system_view); priv->system_motion = gtk_event_controller_motion_new (priv->system_view);
g_signal_connect (priv->system_motion, "motion", G_CALLBACK (text_view_motion), about); g_signal_connect (priv->system_motion, "motion", G_CALLBACK (text_view_motion), about);
priv->license_key = gtk_event_controller_key_new (priv->license_view);
g_signal_connect (priv->license_key, "key-pressed", G_CALLBACK (text_view_key_pressed), about);
priv->system_key = gtk_event_controller_key_new (priv->system_view);
g_signal_connect (priv->system_key, "key-pressed", G_CALLBACK (text_view_key_pressed), about);
/* force defaults */ /* force defaults */
gtk_about_dialog_set_program_name (about, NULL); gtk_about_dialog_set_program_name (about, NULL);
@ -822,6 +830,8 @@ gtk_about_dialog_finalize (GObject *object)
g_object_unref (priv->system_press); g_object_unref (priv->system_press);
g_object_unref (priv->license_motion); g_object_unref (priv->license_motion);
g_object_unref (priv->system_motion); g_object_unref (priv->system_motion);
g_object_unref (priv->license_key);
g_object_unref (priv->system_key);
G_OBJECT_CLASS (gtk_about_dialog_parent_class)->finalize (object); G_OBJECT_CLASS (gtk_about_dialog_parent_class)->finalize (object);
} }
@ -1928,16 +1938,17 @@ follow_if_link (GtkAboutDialog *about,
} }
static gboolean static gboolean
text_view_key_press_event (GtkWidget *text_view, text_view_key_pressed (GtkEventController *controller,
GdkEventKey *event, guint keyval,
guint keycode,
GdkModifierType state,
GtkAboutDialog *about) GtkAboutDialog *about)
{ {
GtkWidget *text_view;
GtkTextIter iter; GtkTextIter iter;
GtkTextBuffer *buffer; GtkTextBuffer *buffer;
guint keyval;
if (!gdk_event_get_keyval ((GdkEvent *) event, &keyval)) text_view = gtk_event_controller_get_widget (controller);
return GDK_EVENT_PROPAGATE;
switch (keyval) switch (keyval)
{ {

View File

@ -157,7 +157,6 @@
<property name="left-margin">8</property> <property name="left-margin">8</property>
<property name="right-margin">8</property> <property name="right-margin">8</property>
<property name="cursor-visible">0</property> <property name="cursor-visible">0</property>
<signal name="key-press-event" handler="text_view_key_press_event" swapped="no"/>
</object> </object>
</child> </child>
</object> </object>
@ -184,7 +183,6 @@
<property name="left-margin">8</property> <property name="left-margin">8</property>
<property name="right-margin">8</property> <property name="right-margin">8</property>
<property name="cursor-visible">0</property> <property name="cursor-visible">0</property>
<signal name="key-press-event" handler="text_view_key_press_event" swapped="no"/>
</object> </object>
</child> </child>
</object> </object>