From 522fab000fc014b9d0787f088bb73e2d2e6d9bf6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timm=20B=C3=A4der?= Date: Sat, 21 Jul 2018 15:25:47 +0200 Subject: [PATCH] widget: Push transform node when neccessary --- gtk/gtkwidget.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c index 4f06f279de..8118e6c673 100644 --- a/gtk/gtkwidget.c +++ b/gtk/gtkwidget.c @@ -13022,6 +13022,7 @@ gtk_widget_create_render_node (GtkWidget *widget, { GtkWidgetClass *klass = GTK_WIDGET_GET_CLASS (widget); GtkWidgetPrivate *priv = gtk_widget_get_instance_private (widget); + const gboolean needs_transform = !graphene_matrix_is_identity (&priv->transform); GtkCssValue *filter_value; double opacity; GtkCssStyle *style; @@ -13041,6 +13042,9 @@ gtk_widget_create_render_node (GtkWidget *widget, G_OBJECT_TYPE_NAME (widget), widget, allocation.width, allocation.height); + if (needs_transform) + gtk_snapshot_push_transform (snapshot, &priv->transform); + filter_value = _gtk_style_context_peek_property (_gtk_widget_get_style_context (widget), GTK_CSS_PROPERTY_FILTER); gtk_css_filter_value_push_snapshot (filter_value, snapshot); @@ -13086,7 +13090,10 @@ gtk_widget_create_render_node (GtkWidget *widget, gtk_widget_maybe_add_debug_render_nodes (widget, snapshot); #endif - gtk_snapshot_pop (snapshot); + if (needs_transform) + gtk_snapshot_pop (snapshot); + + gtk_snapshot_pop (snapshot); /* Debug */ return gtk_snapshot_free_to_node (snapshot); }