[gtk+/wip/baedert/progressbar: 32/36] overlay: Ensure proper child widget order
- From: Timm Bäder <baedert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/baedert/progressbar: 32/36] overlay: Ensure proper child widget order
- Date: Mon, 24 Apr 2017 12:39:36 +0000 (UTC)
commit 005115d5883a7f87f5827c1244f511d65a5f7364
Author: Timm Bäder <mail baedert org>
Date: Sun Apr 23 08:39:15 2017 +0200
overlay: Ensure proper child widget order
Make sure the main widget stays below all the overlay children.
gtk/gtkoverlay.c | 22 ++++++++++++----------
1 files changed, 12 insertions(+), 10 deletions(-)
---
diff --git a/gtk/gtkoverlay.c b/gtk/gtkoverlay.c
index 0817a99..d547a72 100644
--- a/gtk/gtkoverlay.c
+++ b/gtk/gtkoverlay.c
@@ -587,9 +587,10 @@ gtk_overlay_reorder_overlay (GtkOverlay *overlay,
gtk_widget_child_notify (info->widget, "index");
}
- if (gtk_widget_get_visible (child) &&
- gtk_widget_get_visible (GTK_WIDGET (overlay)))
- gtk_widget_queue_resize (GTK_WIDGET (overlay));
+ if (new_link)
+ gtk_widget_insert_before (child, GTK_WIDGET (overlay), ((GtkOverlayChild *)new_link->data)->widget);
+ else
+ gtk_widget_insert_before (child, GTK_WIDGET (overlay), NULL);
}
@@ -831,7 +832,11 @@ gtk_overlay_buildable_add_child (GtkBuildable *buildable,
if (type && strcmp (type, "overlay") == 0)
gtk_overlay_add_overlay (GTK_OVERLAY (buildable), GTK_WIDGET (child));
else if (!type)
- gtk_container_add (GTK_CONTAINER (buildable), GTK_WIDGET (child));
+ {
+ /* Make sure the main-child node is the first one */
+ gtk_widget_insert_after (GTK_WIDGET (child), GTK_WIDGET (buildable), NULL);
+ _gtk_bin_set_child (GTK_BIN (buildable), GTK_WIDGET (child));
+ }
else
GTK_BUILDER_WARN_INVALID_CHILD_TYPE (buildable, type);
}
@@ -889,12 +894,9 @@ gtk_overlay_add_overlay (GtkOverlay *overlay,
priv->children = g_slist_append (priv->children, child);
if (gtk_widget_get_realized (GTK_WIDGET (overlay)))
- {
- child->window = gtk_overlay_create_child_window (overlay, child);
- gtk_widget_set_parent (widget, GTK_WIDGET (overlay));
- }
- else
- gtk_widget_set_parent (widget, GTK_WIDGET (overlay));
+ child->window = gtk_overlay_create_child_window (overlay, child);
+
+ gtk_widget_insert_before (widget, GTK_WIDGET (overlay), NULL);
gtk_widget_child_notify (widget, "index");
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]