mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-12 13:30:19 +00:00
gsk: Make matrix transforms roundtrip better
When we parse a 2D matrix, we produce a 2D transform, and we can easily regenerate a 2D matrix from it. Tests included.
This commit is contained in:
parent
3ae6da10b1
commit
865564b32f
@ -382,15 +382,35 @@ gsk_matrix_transform_print (GskTransform *transform,
|
|||||||
guint i;
|
guint i;
|
||||||
float f[16];
|
float f[16];
|
||||||
|
|
||||||
g_string_append (string, "matrix3d(");
|
if (transform->category >= GSK_TRANSFORM_CATEGORY_2D)
|
||||||
graphene_matrix_to_float (&self->matrix, f);
|
|
||||||
for (i = 0; i < 16; i++)
|
|
||||||
{
|
{
|
||||||
if (i > 0)
|
g_string_append (string, "matrix(");
|
||||||
g_string_append (string, ", ");
|
graphene_matrix_to_float (&self->matrix, f);
|
||||||
string_append_double (string, f[i]);
|
string_append_double (string, f[0]);
|
||||||
|
g_string_append (string, ", ");
|
||||||
|
string_append_double (string, f[1]);
|
||||||
|
g_string_append (string, ", ");
|
||||||
|
string_append_double (string, f[4]);
|
||||||
|
g_string_append (string, ", ");
|
||||||
|
string_append_double (string, f[5]);
|
||||||
|
g_string_append (string, ", ");
|
||||||
|
string_append_double (string, f[12]);
|
||||||
|
g_string_append (string, ", ");
|
||||||
|
string_append_double (string, f[13]);
|
||||||
|
g_string_append (string, ")");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
g_string_append (string, "matrix3d(");
|
||||||
|
graphene_matrix_to_float (&self->matrix, f);
|
||||||
|
for (i = 0; i < 16; i++)
|
||||||
|
{
|
||||||
|
if (i > 0)
|
||||||
|
g_string_append (string, ", ");
|
||||||
|
string_append_double (string, f[i]);
|
||||||
|
}
|
||||||
|
g_string_append (string, ")");
|
||||||
}
|
}
|
||||||
g_string_append (string, ")");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static GskTransform *
|
static GskTransform *
|
||||||
|
@ -967,6 +967,33 @@ test_matrix_transform (void)
|
|||||||
gsk_transform_unref (t2);
|
gsk_transform_unref (t2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_matrix_roundtrip (void)
|
||||||
|
{
|
||||||
|
GskTransform *transform;
|
||||||
|
gboolean res;
|
||||||
|
const char *input;
|
||||||
|
char *str;
|
||||||
|
|
||||||
|
input = "matrix(2, 3, 4, 5, 6, 7)";
|
||||||
|
res = gsk_transform_parse (input, &transform);
|
||||||
|
g_assert_true (res);
|
||||||
|
g_assert_true (gsk_transform_get_category (transform) >= GSK_TRANSFORM_CATEGORY_2D);
|
||||||
|
|
||||||
|
str = gsk_transform_to_string (transform);
|
||||||
|
g_assert_cmpstr (str, ==, input);
|
||||||
|
g_free (str);
|
||||||
|
|
||||||
|
input = "matrix3d(2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17)";
|
||||||
|
res = gsk_transform_parse (input, &transform);
|
||||||
|
g_assert_true (res);
|
||||||
|
g_assert_true (gsk_transform_get_category (transform) < GSK_TRANSFORM_CATEGORY_2D);
|
||||||
|
|
||||||
|
str = gsk_transform_to_string (transform);
|
||||||
|
g_assert_cmpstr (str, ==, input);
|
||||||
|
g_free (str);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main (int argc,
|
main (int argc,
|
||||||
char *argv[])
|
char *argv[])
|
||||||
@ -991,6 +1018,7 @@ main (int argc,
|
|||||||
g_test_add_func ("/transform/rotate", test_rotate_transform);
|
g_test_add_func ("/transform/rotate", test_rotate_transform);
|
||||||
g_test_add_func ("/transform/rotate3d", test_rotate3d_transform);
|
g_test_add_func ("/transform/rotate3d", test_rotate3d_transform);
|
||||||
g_test_add_func ("/transform/matrix", test_matrix_transform);
|
g_test_add_func ("/transform/matrix", test_matrix_transform);
|
||||||
|
g_test_add_func ("/transform/matrix/roundtrip", test_matrix_roundtrip);
|
||||||
|
|
||||||
return g_test_run ();
|
return g_test_run ();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user