mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-13 05:50:10 +00:00
gsk: Add a utility function for rectangles
... and use it.
This commit is contained in:
parent
67610b1242
commit
6f9f18009c
@ -30,6 +30,15 @@
|
||||
#include "gdk/gdktextureprivate.h"
|
||||
#include <cairo-ft.h>
|
||||
|
||||
static inline void
|
||||
gsk_cairo_rectangle (cairo_t *cr,
|
||||
const graphene_rect_t *rect)
|
||||
{
|
||||
cairo_rectangle (cr,
|
||||
rect->origin.x, rect->origin.y,
|
||||
rect->size.width, rect->size.height);
|
||||
}
|
||||
|
||||
static void
|
||||
rectangle_init_from_graphene (cairo_rectangle_int_t *cairo,
|
||||
const graphene_rect_t *graphene)
|
||||
@ -71,9 +80,7 @@ gsk_color_node_draw (GskRenderNode *node,
|
||||
|
||||
gdk_cairo_set_source_rgba (cr, &self->color);
|
||||
|
||||
cairo_rectangle (cr,
|
||||
node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_fill (cr);
|
||||
}
|
||||
|
||||
@ -184,9 +191,7 @@ gsk_linear_gradient_node_draw (GskRenderNode *node,
|
||||
cairo_set_source (cr, pattern);
|
||||
cairo_pattern_destroy (pattern);
|
||||
|
||||
cairo_rectangle (cr,
|
||||
node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_fill (cr);
|
||||
}
|
||||
|
||||
@ -656,9 +661,7 @@ gsk_texture_node_draw (GskRenderNode *node,
|
||||
cairo_pattern_destroy (pattern);
|
||||
cairo_surface_destroy (surface);
|
||||
|
||||
cairo_rectangle (cr,
|
||||
node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_fill (cr);
|
||||
}
|
||||
|
||||
@ -780,9 +783,7 @@ draw_shadow (cairo_t *cr,
|
||||
cairo_set_fill_rule (shadow_cr, CAIRO_FILL_RULE_EVEN_ODD);
|
||||
gsk_rounded_rect_path (box, shadow_cr);
|
||||
if (inset)
|
||||
cairo_rectangle (shadow_cr,
|
||||
clip_box->bounds.origin.x, clip_box->bounds.origin.y,
|
||||
clip_box->bounds.size.width, clip_box->bounds.size.height);
|
||||
gsk_cairo_rectangle (shadow_cr, &clip_box->bounds);
|
||||
|
||||
cairo_fill (shadow_cr);
|
||||
|
||||
@ -1323,9 +1324,7 @@ gsk_outset_shadow_node_draw (GskRenderNode *node,
|
||||
|
||||
cairo_set_fill_rule (cr, CAIRO_FILL_RULE_EVEN_ODD);
|
||||
gsk_rounded_rect_path (&self->outline, cr);
|
||||
cairo_rectangle (cr,
|
||||
clip_box.bounds.origin.x, clip_box.bounds.origin.y,
|
||||
clip_box.bounds.size.width, clip_box.bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &clip_box.bounds);
|
||||
|
||||
cairo_clip (cr);
|
||||
|
||||
@ -1660,9 +1659,7 @@ gsk_cairo_node_get_draw_context (GskRenderNode *node)
|
||||
res = cairo_create (self->surface);
|
||||
}
|
||||
|
||||
cairo_rectangle (res,
|
||||
node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (res, &node->bounds);
|
||||
cairo_clip (res);
|
||||
|
||||
return res;
|
||||
@ -1898,7 +1895,7 @@ gsk_transform_node_draw (GskRenderNode *node,
|
||||
if (gsk_transform_get_category (self->transform) < GSK_TRANSFORM_CATEGORY_2D)
|
||||
{
|
||||
cairo_set_source_rgb (cr, 255 / 255., 105 / 255., 180 / 255.);
|
||||
cairo_rectangle (cr, node->bounds.origin.x, node->bounds.origin.y, node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_fill (cr);
|
||||
return;
|
||||
}
|
||||
@ -2214,8 +2211,7 @@ gsk_opacity_node_draw (GskRenderNode *node,
|
||||
cairo_save (cr);
|
||||
|
||||
/* clip so the push_group() creates a smaller surface */
|
||||
cairo_rectangle (cr, node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_clip (cr);
|
||||
|
||||
cairo_push_group (cr);
|
||||
@ -2345,8 +2341,7 @@ gsk_color_matrix_node_draw (GskRenderNode *node,
|
||||
cairo_save (cr);
|
||||
|
||||
/* clip so the push_group() creates a smaller surface */
|
||||
cairo_rectangle (cr, node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_clip (cr);
|
||||
|
||||
cairo_push_group (cr);
|
||||
@ -2544,15 +2539,12 @@ gsk_repeat_node_draw (GskRenderNode *node,
|
||||
.x0 = - self->child_bounds.origin.x,
|
||||
.y0 = - self->child_bounds.origin.y
|
||||
});
|
||||
|
||||
cairo_set_source (cr, pattern);
|
||||
cairo_rectangle (cr,
|
||||
node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
cairo_fill (cr);
|
||||
|
||||
cairo_pattern_destroy (pattern);
|
||||
cairo_surface_destroy (surface);
|
||||
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_fill (cr);
|
||||
}
|
||||
|
||||
static const GskRenderNodeClass GSK_REPEAT_NODE_CLASS = {
|
||||
@ -2647,9 +2639,7 @@ gsk_clip_node_draw (GskRenderNode *node,
|
||||
|
||||
cairo_save (cr);
|
||||
|
||||
cairo_rectangle (cr,
|
||||
self->clip.origin.x, self->clip.origin.y,
|
||||
self->clip.size.width, self->clip.size.height);
|
||||
gsk_cairo_rectangle (cr, &self->clip);
|
||||
cairo_clip (cr);
|
||||
|
||||
gsk_render_node_draw (self->child, cr);
|
||||
@ -3805,8 +3795,7 @@ gsk_blur_node_draw (GskRenderNode *node,
|
||||
cairo_save (cr);
|
||||
|
||||
/* clip so the push_group() creates a smaller surface */
|
||||
cairo_rectangle (cr, node->bounds.origin.x, node->bounds.origin.y,
|
||||
node->bounds.size.width, node->bounds.size.height);
|
||||
gsk_cairo_rectangle (cr, &node->bounds);
|
||||
cairo_clip (cr);
|
||||
|
||||
cairo_push_group (cr);
|
||||
|
Loading…
Reference in New Issue
Block a user