constraint layout: Measure min/nat size separately

Only constraint the opposite direction if we
actually have a for_size, and measure natural
size after removing the edit constraints. With
these changes, the test that compares constraint
layout to grid layout passes.
This commit is contained in:
Matthias Clasen 2019-06-28 23:00:34 +00:00 committed by Emmanuele Bassi
parent b1f0f4478e
commit 3f36340921

View File

@ -702,7 +702,8 @@ gtk_constraint_layout_measure (GtkLayoutManager *manager,
GtkConstraintSolver *solver; GtkConstraintSolver *solver;
GPtrArray *size_constraints; GPtrArray *size_constraints;
GtkWidget *child; GtkWidget *child;
int value; int min_value;
int nat_value;
solver = gtk_constraint_layout_get_solver (self); solver = gtk_constraint_layout_get_solver (self);
if (solver == NULL) if (solver == NULL)
@ -780,33 +781,34 @@ gtk_constraint_layout_measure (GtkLayoutManager *manager,
g_assert (size != NULL && opposite_size != NULL); g_assert (size != NULL && opposite_size != NULL);
nat_value = gtk_constraint_variable_get_value (size);
/* We impose a temporary value on the size and opposite size of the /* We impose a temporary value on the size and opposite size of the
* layout, with a low weight to let the solver settle towards the * layout, with a low weight to let the solver settle towards the
* natural state of the system. Once we get the value out, we can * natural state of the system. Once we get the value out, we can
* remove these constraints * remove these constraints
*/ */
gtk_constraint_solver_add_edit_variable (solver, size, GTK_CONSTRAINT_WEIGHT_STRONG);
if (for_size > 0) if (for_size > 0)
{ gtk_constraint_solver_add_edit_variable (solver, opposite_size, GTK_CONSTRAINT_WEIGHT_STRONG);
gtk_constraint_solver_add_edit_variable (solver, opposite_size, GTK_CONSTRAINT_WEIGHT_MEDIUM * 2.0); gtk_constraint_solver_begin_edit (solver);
gtk_constraint_solver_begin_edit (solver); gtk_constraint_solver_suggest_value (solver, size, 0.0);
gtk_constraint_solver_suggest_value (solver, opposite_size, for_size); if (for_size > 0)
gtk_constraint_solver_resolve (solver); gtk_constraint_solver_suggest_value (solver, opposite_size, for_size);
gtk_constraint_solver_resolve (solver);
value = gtk_constraint_variable_get_value (size); min_value = gtk_constraint_variable_get_value (size);
gtk_constraint_solver_remove_edit_variable (solver, opposite_size); gtk_constraint_solver_remove_edit_variable (solver, size);
gtk_constraint_solver_end_edit (solver); if (for_size > 0)
} gtk_constraint_solver_remove_edit_variable (solver, opposite_size);
else gtk_constraint_solver_end_edit (solver);
{
value = gtk_constraint_variable_get_value (size);
}
GTK_NOTE (LAYOUT, GTK_NOTE (LAYOUT,
g_print ("layout %p preferred %s size: %.3f (for opposite size: %d)\n", g_print ("layout %p %s size: min %d nat %d (for opposite size: %d)\n",
self, self,
orientation == GTK_ORIENTATION_HORIZONTAL ? "horizontal" : "vertical", orientation == GTK_ORIENTATION_HORIZONTAL ? "horizontal" : "vertical",
gtk_constraint_variable_get_value (size), min_value, nat_value,
for_size)); for_size));
for (guint i = 0; i < size_constraints->len; i++) for (guint i = 0; i < size_constraints->len; i++)
@ -819,10 +821,10 @@ gtk_constraint_layout_measure (GtkLayoutManager *manager,
g_ptr_array_unref (size_constraints); g_ptr_array_unref (size_constraints);
if (minimum != NULL) if (minimum != NULL)
*minimum = value; *minimum = min_value;
if (natural != NULL) if (natural != NULL)
*natural = value; *natural = nat_value;
} }
static void static void