[gtk] widget: Restructure pick() a bit
- From: Timm Bäder <baedert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk] widget: Restructure pick() a bit
- Date: Sun, 26 Jan 2020 17:30:25 +0000 (UTC)
commit 30b37dd7c5e5fa34953f281e459145ea73c7e522
Author: Timm Bäder <mail baedert org>
Date: Sat Jan 25 19:39:28 2020 +0100
widget: Restructure pick() a bit
Don't even invert transforms if we can do it easily ourselves. This also
fixes a small GtkTransform memory leak.
gtk/gtkwidget.c | 59 +++++++++++++++++++++++++++++----------------------------
1 file changed, 30 insertions(+), 29 deletions(-)
---
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index fabb8b0d78..92ef2fec36 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -10479,7 +10479,6 @@ gtk_widget_do_pick (GtkWidget *widget,
child = _gtk_widget_get_prev_sibling (child))
{
GtkWidgetPrivate *child_priv = gtk_widget_get_instance_private (child);
- GskTransform *transform;
GtkWidget *picked;
graphene_point3d_t res;
@@ -10491,39 +10490,41 @@ gtk_widget_do_pick (GtkWidget *widget,
if (child_priv->transform)
{
- transform = gsk_transform_invert (gsk_transform_ref (child_priv->transform));
- if (transform == NULL)
- continue;
- }
- else
- {
- transform = NULL;
- }
+ if (gsk_transform_get_category (child_priv->transform) >= GSK_TRANSFORM_CATEGORY_2D_AFFINE)
+ {
+ graphene_point_t transformed_p;
- if (gsk_transform_get_category (transform) >= GSK_TRANSFORM_CATEGORY_2D_AFFINE)
- {
- graphene_point_t transformed_p;
+ gsk_transform_transform_point (child_priv->transform,
+ &(graphene_point_t) { 0, 0 },
+ &transformed_p);
+
+ graphene_point3d_init (&res, x - transformed_p.x, y - transformed_p.y, 0.);
+ }
+ else
+ {
+ GskTransform *transform;
+ graphene_matrix_t inv;
+ graphene_point3d_t p0, p1;
- gsk_transform_transform_point (transform,
- &(graphene_point_t) { x, y },
- &transformed_p);
- graphene_point3d_init (&res, transformed_p.x, transformed_p.y, 0.);
+ transform = gsk_transform_invert (gsk_transform_ref (child_priv->transform));
+ if (transform == NULL)
+ continue;
+
+ gsk_transform_to_matrix (transform, &inv);
+ gsk_transform_unref (transform);
+ graphene_point3d_init (&p0, x, y, 0);
+ graphene_point3d_init (&p1, x, y, 1);
+ graphene_matrix_transform_point3d (&inv, &p0, &p0);
+ graphene_matrix_transform_point3d (&inv, &p1, &p1);
+ if (fabs (p0.z - p1.z) < 1.f / 4096)
+ continue;
+
+ graphene_point3d_interpolate (&p0, &p1, p0.z / (p0.z - p1.z), &res);
+ }
}
else
{
- graphene_matrix_t inv;
- graphene_point3d_t p0, p1;
-
- gsk_transform_to_matrix (transform, &inv);
- gsk_transform_unref (transform);
- graphene_point3d_init (&p0, x, y, 0);
- graphene_point3d_init (&p1, x, y, 1);
- graphene_matrix_transform_point3d (&inv, &p0, &p0);
- graphene_matrix_transform_point3d (&inv, &p1, &p1);
- if (fabs (p0.z - p1.z) < 1.f / 4096)
- continue;
-
- graphene_point3d_interpolate (&p0, &p1, p0.z / (p0.z - p1.z), &res);
+ graphene_point3d_init (&res, x, y, 0);
}
picked = gtk_widget_do_pick (child, res.x, res.y, flags);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]