[gtk/fixed-layout] Turn GtkFixedLayoutChild:position into a transformation
- From: Emmanuele Bassi <ebassi src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk/fixed-layout] Turn GtkFixedLayoutChild:position into a transformation
- Date: Tue, 26 Mar 2019 19:18:51 +0000 (UTC)
commit 060e30de3f5affd9a98de7d21c8071d86252ee64
Author: Emmanuele Bassi <ebassi gnome org>
Date: Tue Mar 26 19:17:26 2019 +0000
Turn GtkFixedLayoutChild:position into a transformation
This way we can transform children instead of just allocating them at an
offset.
gtk/gtkfixed.c | 22 ++++++++++----
gtk/gtkfixedlayout.c | 83 +++++++++++++++++++++++++++++++---------------------
gtk/gtkfixedlayout.h | 7 ++---
3 files changed, 69 insertions(+), 43 deletions(-)
---
diff --git a/gtk/gtkfixed.c b/gtk/gtkfixed.c
index a0d1b41829..6d33c5bc51 100644
--- a/gtk/gtkfixed.c
+++ b/gtk/gtkfixed.c
@@ -154,6 +154,7 @@ gtk_fixed_put (GtkFixed *fixed,
{
GtkFixedPrivate *priv = gtk_fixed_get_instance_private (fixed);
GtkFixedLayoutChild *child_info;
+ GskTransform *transform = NULL;
g_return_if_fail (GTK_IS_FIXED (fixed));
g_return_if_fail (GTK_IS_WIDGET (widget));
@@ -162,7 +163,10 @@ gtk_fixed_put (GtkFixed *fixed,
gtk_widget_set_parent (widget, GTK_WIDGET (fixed));
child_info = GTK_FIXED_LAYOUT_CHILD (gtk_layout_manager_get_layout_child (priv->layout, widget));
- gtk_fixed_layout_child_set_position (child_info, &GRAPHENE_POINT_INIT (x, y));
+
+ transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (x, y));
+ gtk_fixed_layout_child_set_position (child_info, transform);
+ gsk_transform_unref (transform);
}
/**
@@ -183,19 +187,21 @@ gtk_fixed_get_child_position (GtkFixed *fixed,
{
GtkFixedPrivate *priv = gtk_fixed_get_instance_private (fixed);
GtkFixedLayoutChild *child_info;
- graphene_point_t pos;
+ float pos_x = 0.f, pos_y = 0.f;
+ GskTransform *transform;
g_return_if_fail (GTK_IS_FIXED (fixed));
g_return_if_fail (GTK_IS_WIDGET (widget));
g_return_if_fail (gtk_widget_get_parent (widget) == GTK_WIDGET (fixed));
child_info = GTK_FIXED_LAYOUT_CHILD (gtk_layout_manager_get_layout_child (priv->layout, widget));
- gtk_fixed_layout_child_get_position (child_info, &pos);
+ transform = gtk_fixed_layout_child_get_position (child_info);
+ gsk_transform_to_translate (transform, &pos_x, &pos_y);
if (x != NULL)
- *x = floorf (pos.x);
+ *x = floorf (pos_x);
if (y != NULL)
- *y = floorf (pos.y);
+ *y = floorf (pos_y);
}
/**
@@ -215,13 +221,17 @@ gtk_fixed_move (GtkFixed *fixed,
{
GtkFixedPrivate *priv = gtk_fixed_get_instance_private (fixed);
GtkFixedLayoutChild *child_info;
+ GskTransform *transform = NULL;
g_return_if_fail (GTK_IS_FIXED (fixed));
g_return_if_fail (GTK_IS_WIDGET (widget));
g_return_if_fail (gtk_widget_get_parent (widget) == GTK_WIDGET (fixed));
child_info = GTK_FIXED_LAYOUT_CHILD (gtk_layout_manager_get_layout_child (priv->layout, widget));
- gtk_fixed_layout_child_set_position (child_info, &GRAPHENE_POINT_INIT (x, y));
+
+ transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (x, y));
+ gtk_fixed_layout_child_set_position (child_info, transform);
+ gsk_transform_unref (transform);
}
static void
diff --git a/gtk/gtkfixedlayout.c b/gtk/gtkfixedlayout.c
index abddfb8849..0895753edf 100644
--- a/gtk/gtkfixedlayout.c
+++ b/gtk/gtkfixedlayout.c
@@ -77,7 +77,7 @@ struct _GtkFixedLayoutChild
{
GtkLayoutChild parent_instance;
- graphene_point_t position;
+ GskTransform *position;
};
enum
@@ -131,6 +131,16 @@ gtk_fixed_layout_child_get_property (GObject *gobject,
}
}
+static void
+gtk_fixed_layout_child_finalize (GObject *gobject)
+{
+ GtkFixedLayoutChild *self = GTK_FIXED_LAYOUT_CHILD (gobject);
+
+ gsk_transform_unref (self->position);
+
+ G_OBJECT_CLASS (gtk_fixed_layout_child_parent_class)->finalize (gobject);
+}
+
static void
gtk_fixed_layout_child_class_init (GtkFixedLayoutChildClass *klass)
{
@@ -138,12 +148,13 @@ gtk_fixed_layout_child_class_init (GtkFixedLayoutChildClass *klass)
gobject_class->set_property = gtk_fixed_layout_child_set_property;
gobject_class->get_property = gtk_fixed_layout_child_get_property;
+ gobject_class->finalize = gtk_fixed_layout_child_finalize;
child_props[PROP_CHILD_POSITION] =
g_param_spec_boxed ("position",
P_("Position"),
P_("The position of a child of a fixed layout"),
- GRAPHENE_TYPE_POINT,
+ GSK_TYPE_TRANSFORM,
G_PARAM_READWRITE |
G_PARAM_STATIC_STRINGS |
G_PARAM_EXPLICIT_NOTIFY);
@@ -159,23 +170,19 @@ gtk_fixed_layout_child_init (GtkFixedLayoutChild *self)
/**
* gtk_fixed_layout_child_set_position:
* @child: a #GtkFixedLayoutChild
- * @position: the position of the child
+ * @position: a #GskTransform
*
- * Sets the position of the child of a #GtkFixedLayout.
+ * Sets the transformation of the child of a #GtkFixedLayout.
*/
void
-gtk_fixed_layout_child_set_position (GtkFixedLayoutChild *child,
- const graphene_point_t *position)
+gtk_fixed_layout_child_set_position (GtkFixedLayoutChild *child,
+ GskTransform *position)
{
GtkLayoutManager *layout;
g_return_if_fail (GTK_IS_FIXED_LAYOUT_CHILD (child));
- g_return_if_fail (position != NULL);
-
- if (graphene_point_equal (&child->position, position))
- return;
- child->position = *position;
+ child->position = gsk_transform_transform (child->position, position);
layout = gtk_layout_child_get_layout_manager (GTK_LAYOUT_CHILD (child));
gtk_layout_manager_layout_changed (layout);
@@ -186,18 +193,17 @@ gtk_fixed_layout_child_set_position (GtkFixedLayoutChild *child,
/**
* gtk_fixed_layout_child_get_position:
* @child: a #GtkFixedLayoutChild
- * @position: (out caller-allocates): the position of the child
*
- * Retrieves the position of the child of a #GtkFixedLayout.
+ * Retrieves the transformation of the child of a #GtkFixedLayout.
+ *
+ * Returns: (transfer none) (nullable): a #GskTransform
*/
-void
-gtk_fixed_layout_child_get_position (GtkFixedLayoutChild *child,
- graphene_point_t *position)
+GskTransform *
+gtk_fixed_layout_child_get_position (GtkFixedLayoutChild *child)
{
- g_return_if_fail (GTK_IS_FIXED_LAYOUT_CHILD (child));
- g_return_if_fail (position != NULL);
+ g_return_val_if_fail (GTK_IS_FIXED_LAYOUT_CHILD (child), NULL);
- *position = child->position;
+ return child->position;
}
G_DEFINE_TYPE (GtkFixedLayout, gtk_fixed_layout, GTK_TYPE_LAYOUT_MANAGER)
@@ -221,25 +227,38 @@ gtk_fixed_layout_measure (GtkLayoutManager *layout_manager,
child != NULL;
child = _gtk_widget_get_next_sibling (child))
{
- int child_min = 0;
- int child_nat = 0;
+ int child_min = 0, child_nat = 0;
+ int child_min_opp = 0, child_nat_opp = 0;
+ graphene_rect_t min_rect, nat_rect;
if (!gtk_widget_get_visible (child))
continue;
child_info = GTK_FIXED_LAYOUT_CHILD (gtk_layout_manager_get_layout_child (layout_manager, child));
- gtk_widget_measure (child, orientation, -1, &child_min, &child_nat, NULL, NULL);
+ gtk_widget_measure (child, orientation, -1,
+ &child_min, &child_nat,
+ NULL, NULL);
+ gtk_widget_measure (child, OPPOSITE_ORIENTATION (orientation), -1,
+ &child_min_opp, &child_nat_opp,
+ NULL, NULL);
+
+ gsk_transform_transform_bounds (child_info->position,
+ &GRAPHENE_RECT_INIT (0.f, 0.f, child_min, child_min_opp),
+ &min_rect);
+ gsk_transform_transform_bounds (child_info->position,
+ &GRAPHENE_RECT_INIT (0.f, 0.f, child_nat, child_nat_opp),
+ &nat_rect);
if (orientation == GTK_ORIENTATION_HORIZONTAL)
{
- minimum_size = MAX (minimum_size, child_info->position.x + child_min);
- natural_size = MAX (natural_size, child_info->position.x + child_nat);
+ minimum_size = MAX (minimum_size, min_rect.origin.x + min_rect.size.width);
+ natural_size = MAX (natural_size, nat_rect.origin.x + nat_rect.size.width);
}
else
{
- minimum_size = MAX (minimum_size, child_info->position.y + child_min);
- natural_size = MAX (natural_size, child_info->position.y + child_nat);
+ minimum_size = MAX (minimum_size, min_rect.origin.y + min_rect.size.height);
+ natural_size = MAX (natural_size, nat_rect.origin.y + nat_rect.size.height);
}
}
@@ -271,13 +290,11 @@ gtk_fixed_layout_allocate (GtkLayoutManager *layout_manager,
child_info = GTK_FIXED_LAYOUT_CHILD (gtk_layout_manager_get_layout_child (layout_manager, child));
gtk_widget_get_preferred_size (child, &child_req, NULL);
- gtk_widget_size_allocate (child,
- &(GtkAllocation) {
- .x = child_info->position.x,
- .y = child_info->position.y,
- .width = child_req.width,
- .height = child_req.height,
- }, -1);
+ gtk_widget_allocate (child,
+ child_req.width,
+ child_req.height,
+ -1,
+ child_info->position);
}
}
diff --git a/gtk/gtkfixedlayout.h b/gtk/gtkfixedlayout.h
index 8600091b19..090aceb138 100644
--- a/gtk/gtkfixedlayout.h
+++ b/gtk/gtkfixedlayout.h
@@ -41,10 +41,9 @@ GDK_AVAILABLE_IN_ALL
G_DECLARE_FINAL_TYPE (GtkFixedLayoutChild, gtk_fixed_layout_child, GTK, FIXED_LAYOUT_CHILD, GtkLayoutChild)
GDK_AVAILABLE_IN_ALL
-void gtk_fixed_layout_child_set_position (GtkFixedLayoutChild *child,
- const graphene_point_t *position);
+void gtk_fixed_layout_child_set_position (GtkFixedLayoutChild *child,
+ GskTransform *position);
GDK_AVAILABLE_IN_ALL
-void gtk_fixed_layout_child_get_position (GtkFixedLayoutChild *child,
- graphene_point_t *position);
+GskTransform * gtk_fixed_layout_child_get_position (GtkFixedLayoutChild *child);
G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]