[gtk+/wip/matthiasc/kill-event-signals: 70/123] testoverlay: Use an event controller



commit c54047bbceed36b7bd2f212d3230343843f17149
Author: Matthias Clasen <mclasen redhat com>
Date:   Mon Jan 1 11:15:22 2018 -0500

    testoverlay: Use an event controller
    
    We can stop using ::enter-notify-event here, and use
    our new motion event controller instead.

 tests/testoverlay.c |   11 ++++++++---
 1 files changed, 8 insertions(+), 3 deletions(-)
---
diff --git a/tests/testoverlay.c b/tests/testoverlay.c
index ac5cc4d..9eea960 100644
--- a/tests/testoverlay.c
+++ b/tests/testoverlay.c
@@ -315,8 +315,10 @@ test_builder (void)
 }
 
 static void
-on_enter (GtkWidget *child, GdkEventCrossing *event, GtkWidget *overlay)
+on_enter (GtkEventController *controller, GtkWidget *overlay)
 {
+  GtkWidget *child = gtk_event_controller_get_widget (controller);
+
   if (gtk_widget_get_halign (child) == GTK_ALIGN_START)
     gtk_widget_set_halign (child, GTK_ALIGN_END);
   else
@@ -336,6 +338,7 @@ test_chase (void)
   GtkTextBuffer *buffer;
   gchar *contents;
   gsize len;
+  GtkEventController *controller;
 
   win = gtk_window_new (GTK_WINDOW_TOPLEVEL);
   gtk_window_set_title (GTK_WINDOW (win), "Chase");
@@ -369,8 +372,10 @@ test_chase (void)
   gtk_overlay_add_overlay (GTK_OVERLAY (overlay), child);
   g_object_set (child, "margin", 4, NULL);
 
-  g_signal_connect (child, "enter-notify-event",
-                    G_CALLBACK (on_enter), overlay);
+  controller = gtk_event_controller_motion_new (child);
+  g_object_set_data_full (G_OBJECT (child), "motion", controller, g_object_unref);
+  g_signal_connect (controller, "enter", G_CALLBACK (on_enter), overlay);
+
   return win;
 }
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]