summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2021-07-15 18:31:22 +0000
committerMatthias Clasen <mclasen@redhat.com>2021-07-15 18:31:22 +0000
commitb99beeb552fdb4310906160ea25d78481a67468f (patch)
tree15e3a7149baa497a5e47fb7924a46b69b432b858
parent67952a91420bc6230eac7f68700b38595322813f (diff)
parent433233258bf1c04ab3e717dd097e3953f1d3ff84 (diff)
downloadgtk+-b99beeb552fdb4310906160ea25d78481a67468f.tar.gz
Merge branch 'wip/baedert/for-master' into 'master'
snapshot: Replace trivial gradients with color nodes See merge request GNOME/gtk!3753
-rw-r--r--gtk/gtksnapshot.c163
1 files changed, 114 insertions, 49 deletions
diff --git a/gtk/gtksnapshot.c b/gtk/gtksnapshot.c
index b0b1222c66..af8608b682 100644
--- a/gtk/gtksnapshot.c
+++ b/gtk/gtksnapshot.c
@@ -2159,12 +2159,9 @@ gtk_snapshot_append_linear_gradient (GtkSnapshot *snapshot,
{
GskRenderNode *node;
graphene_rect_t real_bounds;
- graphene_point_t real_start_point;
- graphene_point_t real_end_point;
float scale_x, scale_y, dx, dy;
const GdkRGBA *first_color;
gboolean need_gradient = FALSE;
- int i;
g_return_if_fail (snapshot != NULL);
g_return_if_fail (start_point != NULL);
@@ -2174,13 +2171,9 @@ gtk_snapshot_append_linear_gradient (GtkSnapshot *snapshot,
gtk_snapshot_ensure_affine (snapshot, &scale_x, &scale_y, &dx, &dy);
gtk_graphene_rect_scale_affine (bounds, scale_x, scale_y, dx, dy, &real_bounds);
- real_start_point.x = scale_x * start_point->x + dx;
- real_start_point.y = scale_y * start_point->y + dy;
- real_end_point.x = scale_x * end_point->x + dx;
- real_end_point.y = scale_y * end_point->y + dy;
first_color = &stops[0].color;
- for (i = 0; i < n_stops; i ++)
+ for (gsize i = 0; i < n_stops; i ++)
{
if (!gdk_rgba_equal (first_color, &stops[i].color))
{
@@ -2190,13 +2183,24 @@ gtk_snapshot_append_linear_gradient (GtkSnapshot *snapshot,
}
if (need_gradient)
- node = gsk_linear_gradient_node_new (&real_bounds,
- &real_start_point,
- &real_end_point,
- stops,
- n_stops);
+ {
+ graphene_point_t real_start_point, real_end_point;
+
+ real_start_point.x = scale_x * start_point->x + dx;
+ real_start_point.y = scale_y * start_point->y + dy;
+ real_end_point.x = scale_x * end_point->x + dx;
+ real_end_point.y = scale_y * end_point->y + dy;
+
+ node = gsk_linear_gradient_node_new (&real_bounds,
+ &real_start_point,
+ &real_end_point,
+ stops,
+ n_stops);
+ }
else
- node = gsk_color_node_new (first_color, &real_bounds);
+ {
+ node = gsk_color_node_new (first_color, &real_bounds);
+ }
gtk_snapshot_append_node_internal (snapshot, node);
}
@@ -2223,9 +2227,9 @@ gtk_snapshot_append_repeating_linear_gradient (GtkSnapshot *snapshot,
{
GskRenderNode *node;
graphene_rect_t real_bounds;
- graphene_point_t real_start_point;
- graphene_point_t real_end_point;
float scale_x, scale_y, dx, dy;
+ gboolean need_gradient = FALSE;
+ const GdkRGBA *first_color;
g_return_if_fail (snapshot != NULL);
g_return_if_fail (start_point != NULL);
@@ -2235,16 +2239,36 @@ gtk_snapshot_append_repeating_linear_gradient (GtkSnapshot *snapshot,
gtk_snapshot_ensure_affine (snapshot, &scale_x, &scale_y, &dx, &dy);
gtk_graphene_rect_scale_affine (bounds, scale_x, scale_y, dx, dy, &real_bounds);
- real_start_point.x = scale_x * start_point->x + dx;
- real_start_point.y = scale_y * start_point->y + dy;
- real_end_point.x = scale_x * end_point->x + dx;
- real_end_point.y = scale_y * end_point->y + dy;
- node = gsk_repeating_linear_gradient_node_new (&real_bounds,
- &real_start_point,
- &real_end_point,
- stops,
- n_stops);
+ first_color = &stops[0].color;
+ for (gsize i = 0; i < n_stops; i ++)
+ {
+ if (!gdk_rgba_equal (first_color, &stops[i].color))
+ {
+ need_gradient = TRUE;
+ break;
+ }
+ }
+
+ if (need_gradient)
+ {
+ graphene_point_t real_start_point, real_end_point;
+
+ real_start_point.x = scale_x * start_point->x + dx;
+ real_start_point.y = scale_y * start_point->y + dy;
+ real_end_point.x = scale_x * end_point->x + dx;
+ real_end_point.y = scale_y * end_point->y + dy;
+
+ node = gsk_repeating_linear_gradient_node_new (&real_bounds,
+ &real_start_point,
+ &real_end_point,
+ stops,
+ n_stops);
+ }
+ else
+ {
+ node = gsk_color_node_new (first_color, &real_bounds);
+ }
gtk_snapshot_append_node_internal (snapshot, node);
}
@@ -2338,8 +2362,9 @@ gtk_snapshot_append_radial_gradient (GtkSnapshot *snapshot,
{
GskRenderNode *node;
graphene_rect_t real_bounds;
- graphene_point_t real_center;
float scale_x, scale_y, dx, dy;
+ gboolean need_gradient = FALSE;
+ const GdkRGBA *first_color;
g_return_if_fail (snapshot != NULL);
g_return_if_fail (center != NULL);
@@ -2348,17 +2373,37 @@ gtk_snapshot_append_radial_gradient (GtkSnapshot *snapshot,
gtk_snapshot_ensure_affine (snapshot, &scale_x, &scale_y, &dx, &dy);
gtk_graphene_rect_scale_affine (bounds, scale_x, scale_y, dx, dy, &real_bounds);
- real_center.x = scale_x * center->x + dx;
- real_center.y = scale_y * center->y + dy;
-
- node = gsk_radial_gradient_node_new (&real_bounds,
- &real_center,
- hradius * scale_x,
- vradius * scale_y,
- start,
- end,
- stops,
- n_stops);
+
+ first_color = &stops[0].color;
+ for (gsize i = 0; i < n_stops; i ++)
+ {
+ if (!gdk_rgba_equal (first_color, &stops[i].color))
+ {
+ need_gradient = TRUE;
+ break;
+ }
+ }
+
+ if (need_gradient)
+ {
+ graphene_point_t real_center;
+
+ real_center.x = scale_x * center->x + dx;
+ real_center.y = scale_y * center->y + dy;
+
+ node = gsk_radial_gradient_node_new (&real_bounds,
+ &real_center,
+ hradius * scale_x,
+ vradius * scale_y,
+ start,
+ end,
+ stops,
+ n_stops);
+ }
+ else
+ {
+ node = gsk_color_node_new (first_color, &real_bounds);
+ }
gtk_snapshot_append_node_internal (snapshot, node);
}
@@ -2391,8 +2436,9 @@ gtk_snapshot_append_repeating_radial_gradient (GtkSnapshot *snapshot,
{
GskRenderNode *node;
graphene_rect_t real_bounds;
- graphene_point_t real_center;
float scale_x, scale_y, dx, dy;
+ gboolean need_gradient = FALSE;
+ const GdkRGBA *first_color;
g_return_if_fail (snapshot != NULL);
g_return_if_fail (center != NULL);
@@ -2401,17 +2447,36 @@ gtk_snapshot_append_repeating_radial_gradient (GtkSnapshot *snapshot,
gtk_snapshot_ensure_affine (snapshot, &scale_x, &scale_y, &dx, &dy);
gtk_graphene_rect_scale_affine (bounds, scale_x, scale_y, dx, dy, &real_bounds);
- real_center.x = scale_x * center->x + dx;
- real_center.y = scale_y * center->y + dy;
-
- node = gsk_repeating_radial_gradient_node_new (&real_bounds,
- &real_center,
- hradius * scale_x,
- vradius * scale_y,
- start,
- end,
- stops,
- n_stops);
+
+ first_color = &stops[0].color;
+ for (gsize i = 0; i < n_stops; i ++)
+ {
+ if (!gdk_rgba_equal (first_color, &stops[i].color))
+ {
+ need_gradient = TRUE;
+ break;
+ }
+ }
+
+ if (need_gradient)
+ {
+ graphene_point_t real_center;
+
+ real_center.x = scale_x * center->x + dx;
+ real_center.y = scale_y * center->y + dy;
+ node = gsk_repeating_radial_gradient_node_new (&real_bounds,
+ &real_center,
+ hradius * scale_x,
+ vradius * scale_y,
+ start,
+ end,
+ stops,
+ n_stops);
+ }
+ else
+ {
+ node = gsk_color_node_new (first_color, &real_bounds);
+ }
gtk_snapshot_append_node_internal (snapshot, node);
}