[gtk/wip/matthiasc/popup5: 47/75] popover: Stop using gtk_widget_register_surface
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/wip/matthiasc/popup5: 47/75] popover: Stop using gtk_widget_register_surface
- Date: Mon, 29 Apr 2019 19:45:52 +0000 (UTC)
commit 58cdfd4ee7b0dc588be0201c711352b7b8ead385
Author: Matthias Clasen <mclasen redhat com>
Date: Fri Apr 19 20:14:44 2019 +0000
popover: Stop using gtk_widget_register_surface
The GtkRoot implementations are expected to handle
the necessary surface setup themselves, going forward.
gtk/gtkpopover.c | 29 ++++++++++++++++++++++++++---
1 file changed, 26 insertions(+), 3 deletions(-)
---
diff --git a/gtk/gtkpopover.c b/gtk/gtkpopover.c
index cccba821d4..98fca2bdeb 100644
--- a/gtk/gtkpopover.c
+++ b/gtk/gtkpopover.c
@@ -330,12 +330,30 @@ surface_state_changed (GtkWidget *widget)
}
static void
-surface_size_changed (GtkWindow *window,
+surface_size_changed (GtkWidget *widget,
guint width,
guint height)
{
}
+static gboolean
+surface_render (GdkSurface *surface,
+ cairo_region_t *region,
+ GtkWidget *widget)
+{
+ gtk_widget_render (widget, surface, region);
+ return TRUE;
+}
+
+static gboolean
+surface_event (GdkSurface *surface,
+ GdkEvent *event,
+ GtkWidget *widget)
+{
+ gtk_main_do_event (event);
+ return TRUE;
+}
+
static void
measure_contents (GtkGizmo *gizmo,
GtkOrientation orientation,
@@ -452,10 +470,12 @@ gtk_popover_realize (GtkWidget *widget)
priv->surface = gdk_surface_new_popup_full (display, gtk_widget_get_surface (priv->relative_to));
gtk_widget_set_surface (widget, priv->surface);
+ gdk_surface_set_widget (priv->surface, widget);
+
g_signal_connect_swapped (priv->surface, "notify::state", G_CALLBACK (surface_state_changed), widget);
g_signal_connect_swapped (priv->surface, "size-changed", G_CALLBACK (surface_size_changed), widget);
-
- gtk_widget_register_surface (widget, priv->surface);
+ g_signal_connect (priv->surface, "render", G_CALLBACK (surface_render), widget);
+ g_signal_connect (priv->surface, "event", G_CALLBACK (surface_event), widget);
GTK_WIDGET_CLASS (gtk_popover_parent_class)->realize (widget);
@@ -475,6 +495,9 @@ gtk_popover_unrealize (GtkWidget *widget)
g_signal_handlers_disconnect_by_func (priv->surface, surface_state_changed, widget);
g_signal_handlers_disconnect_by_func (priv->surface, surface_size_changed, widget);
+ g_signal_handlers_disconnect_by_func (priv->surface, surface_render, widget);
+ g_signal_handlers_disconnect_by_func (priv->surface, surface_event, widget);
+ gdk_surface_set_widget (priv->surface, NULL);
g_clear_object (&priv->surface);
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]