Merge branch 'matthiasc/for-main' into 'main'

gsk: Inline some more rect functions

See merge request GNOME/gtk!6789
This commit is contained in:
Matthias Clasen 2024-01-20 17:11:48 +00:00
commit 8d00af6351
5 changed files with 61 additions and 44 deletions

View File

@ -830,8 +830,8 @@ rounded_rect_scale_corners (const GskRoundedRect *rect,
{ {
for (guint i = 0; i < G_N_ELEMENTS (out_rect->corner); i++) for (guint i = 0; i < G_N_ELEMENTS (out_rect->corner); i++)
{ {
out_rect->corner[i].width = rect->corner[i].width * fabs (scale_x); out_rect->corner[i].width = rect->corner[i].width * fabsf (scale_x);
out_rect->corner[i].height = rect->corner[i].height * fabs (scale_y); out_rect->corner[i].height = rect->corner[i].height * fabsf (scale_y);
} }
if (scale_x < 0) if (scale_x < 0)
@ -1173,8 +1173,8 @@ gsk_gl_render_job_visit_as_fallback (GskGLRenderJob *job,
{ {
float scale_x = job->scale_x; float scale_x = job->scale_x;
float scale_y = job->scale_y; float scale_y = job->scale_y;
int surface_width = ceilf (node->bounds.size.width * fabs (scale_x)); int surface_width = ceilf (node->bounds.size.width * fabsf (scale_x));
int surface_height = ceilf (node->bounds.size.height * fabs (scale_y)); int surface_height = ceilf (node->bounds.size.height * fabsf (scale_y));
GdkTexture *texture; GdkTexture *texture;
cairo_surface_t *surface; cairo_surface_t *surface;
cairo_surface_t *rendered_surface; cairo_surface_t *rendered_surface;
@ -1203,7 +1203,7 @@ gsk_gl_render_job_visit_as_fallback (GskGLRenderJob *job,
surface_width, surface_width,
surface_height); surface_height);
cairo_surface_set_device_scale (rendered_surface, fabs (scale_x), fabs (scale_y)); cairo_surface_set_device_scale (rendered_surface, fabsf (scale_x), fabsf (scale_y));
cr = cairo_create (rendered_surface); cr = cairo_create (rendered_surface);
cairo_save (cr); cairo_save (cr);
@ -1217,16 +1217,16 @@ gsk_gl_render_job_visit_as_fallback (GskGLRenderJob *job,
surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32,
surface_width, surface_width,
surface_height); surface_height);
cairo_surface_set_device_scale (surface, fabs (scale_x), fabs (scale_y)); cairo_surface_set_device_scale (surface, fabsf (scale_x), fabsf (scale_y));
cr = cairo_create (surface); cr = cairo_create (surface);
/* We draw upside down here, so it matches what GL does. */ /* We draw upside down here, so it matches what GL does. */
cairo_save (cr); cairo_save (cr);
cairo_scale (cr, scale_x < 0 ? -1 : 1, scale_y < 0 ? 1 : -1); cairo_scale (cr, scale_x < 0 ? -1 : 1, scale_y < 0 ? 1 : -1);
cairo_translate (cr, scale_x < 0 ? - surface_width / fabs (scale_x) : 0, cairo_translate (cr, scale_x < 0 ? - surface_width / fabsf (scale_x) : 0,
scale_y < 0 ? 0 : - surface_height / fabs (scale_y)); scale_y < 0 ? 0 : - surface_height / fabsf (scale_y));
cairo_set_source_surface (cr, rendered_surface, 0, 0); cairo_set_source_surface (cr, rendered_surface, 0, 0);
cairo_rectangle (cr, 0, 0, surface_width / fabs (scale_x), surface_height / fabs (scale_y)); cairo_rectangle (cr, 0, 0, surface_width / fabsf (scale_x), surface_height / fabsf (scale_y));
cairo_fill (cr); cairo_fill (cr);
cairo_restore (cr); cairo_restore (cr);
cairo_destroy (cr); cairo_destroy (cr);
@ -1432,10 +1432,10 @@ blur_node (GskGLRenderJob *job,
offscreen->texture_id = blur_offscreen (job, offscreen->texture_id = blur_offscreen (job,
offscreen, offscreen,
texture_width * fabs (scale_x), texture_width * fabsf (scale_x),
texture_height * fabs (scale_y), texture_height * fabsf (scale_y),
blur_radius * fabs (scale_x), blur_radius * fabsf (scale_x),
blur_radius * fabs (scale_y)); blur_radius * fabsf (scale_y));
init_full_texture_region (offscreen); init_full_texture_region (offscreen);
} }
@ -2019,9 +2019,9 @@ result_is_axis_aligned (GskTransform *transform,
for (guint i = 0; i < 4; i++) for (guint i = 0; i < 4; i++)
{ {
p = graphene_quad_get_point (&q, i); p = graphene_quad_get_point (&q, i);
if (fabs (p->x - b1.x) > FLT_EPSILON && fabs (p->x - b2.x) > FLT_EPSILON) if (fabsf (p->x - b1.x) > FLT_EPSILON && fabsf (p->x - b2.x) > FLT_EPSILON)
return FALSE; return FALSE;
if (fabs (p->y - b1.y) > FLT_EPSILON && fabs (p->y - b2.y) > FLT_EPSILON) if (fabsf (p->y - b1.y) > FLT_EPSILON && fabsf (p->y - b2.y) > FLT_EPSILON)
return FALSE; return FALSE;
} }
@ -2304,8 +2304,8 @@ gsk_gl_render_job_visit_blurred_inset_shadow_node (GskGLRenderJob *job,
&offscreen, &offscreen,
texture_width, texture_width,
texture_height, texture_height,
blur_radius * fabs (scale_x), blur_radius * fabsf (scale_x),
blur_radius * fabs (scale_y)); blur_radius * fabsf (scale_y));
gsk_gl_driver_release_render_target (job->driver, render_target, TRUE); gsk_gl_driver_release_render_target (job->driver, render_target, TRUE);
@ -2501,8 +2501,8 @@ gsk_gl_render_job_visit_blurred_outset_shadow_node (GskGLRenderJob *job,
do_slicing = TRUE; do_slicing = TRUE;
} }
texture_width = (int)ceil ((scaled_outline.bounds.size.width + blur_extra) * scale_x); texture_width = (int)ceilf ((scaled_outline.bounds.size.width + blur_extra) * scale_x);
texture_height = (int)ceil ((scaled_outline.bounds.size.height + blur_extra) * scale_y); texture_height = (int)ceilf ((scaled_outline.bounds.size.height + blur_extra) * scale_y);
scaled_outline.bounds.origin.x = extra_blur_pixels_x; scaled_outline.bounds.origin.x = extra_blur_pixels_x;
scaled_outline.bounds.origin.y = extra_blur_pixels_y; scaled_outline.bounds.origin.y = extra_blur_pixels_y;
@ -2577,8 +2577,8 @@ gsk_gl_render_job_visit_blurred_outset_shadow_node (GskGLRenderJob *job,
&offscreen, &offscreen,
texture_width, texture_width,
texture_height, texture_height,
blur_radius * fabs (scale_x), blur_radius * fabsf (scale_x),
blur_radius * fabs (scale_y)); blur_radius * fabsf (scale_y));
gsk_gl_shadow_library_insert (job->driver->shadows_library, gsk_gl_shadow_library_insert (job->driver->shadows_library,
&scaled_outline, &scaled_outline,
@ -2834,7 +2834,7 @@ gsk_gl_render_job_visit_cross_fade_node (GskGLRenderJob *job,
offscreen_end.reset_clip = TRUE; offscreen_end.reset_clip = TRUE;
offscreen_end.bounds = &node->bounds; offscreen_end.bounds = &node->bounds;
gsk_gl_render_job_set_modelview (job, gsk_transform_scale (NULL, fabs (job->scale_x), fabs (job->scale_y))); gsk_gl_render_job_set_modelview (job, gsk_transform_scale (NULL, fabsf (job->scale_x), fabsf (job->scale_y)));
if (!gsk_gl_render_job_visit_node_with_offscreen (job, start_node, &offscreen_start)) if (!gsk_gl_render_job_visit_node_with_offscreen (job, start_node, &offscreen_start))
{ {
@ -2964,7 +2964,7 @@ gsk_gl_render_job_visit_text_node (GskGLRenderJob *job,
const PangoFont *font = gsk_text_node_get_font (node); const PangoFont *font = gsk_text_node_get_font (node);
const PangoGlyphInfo *glyphs = gsk_text_node_get_glyphs (node, NULL); const PangoGlyphInfo *glyphs = gsk_text_node_get_glyphs (node, NULL);
const graphene_point_t *offset = gsk_text_node_get_offset (node); const graphene_point_t *offset = gsk_text_node_get_offset (node);
float text_scale = MAX (fabs (job->scale_x), fabs (job->scale_y)); /* TODO: Fix for uneven scales? */ float text_scale = MAX (fabsf (job->scale_x), fabsf (job->scale_y)); /* TODO: Fix for uneven scales? */
guint num_glyphs = gsk_text_node_get_num_glyphs (node); guint num_glyphs = gsk_text_node_get_num_glyphs (node);
float x = offset->x + job->offset_x; float x = offset->x + job->offset_x;
float y = offset->y + job->offset_y; float y = offset->y + job->offset_y;
@ -3263,7 +3263,7 @@ gsk_gl_render_job_visit_blend_node (GskGLRenderJob *job,
bottom_offscreen.force_offscreen = TRUE; bottom_offscreen.force_offscreen = TRUE;
bottom_offscreen.reset_clip = TRUE; bottom_offscreen.reset_clip = TRUE;
gsk_gl_render_job_set_modelview (job, gsk_transform_scale (NULL, fabs (job->scale_x), fabs (job->scale_y))); gsk_gl_render_job_set_modelview (job, gsk_transform_scale (NULL, fabsf (job->scale_x), fabsf (job->scale_y)));
/* TODO: We create 2 textures here as big as the blend node, but both the /* TODO: We create 2 textures here as big as the blend node, but both the
* start and the end node might be a lot smaller than that. */ * start and the end node might be a lot smaller than that. */
@ -3344,8 +3344,8 @@ gsk_gl_render_job_texture_mask_for_color (GskGLRenderJob *job,
gboolean use_mipmap; gboolean use_mipmap;
guint16 cc[4]; guint16 cc[4];
use_mipmap = (scale_x * fabs (job->scale_x)) < 0.5 || use_mipmap = (scale_x * fabsf (job->scale_x)) < 0.5 ||
(scale_y * fabs (job->scale_y)) < 0.5; (scale_y * fabsf (job->scale_y)) < 0.5;
rgba_to_half (rgba, cc); rgba_to_half (rgba, cc);
gsk_gl_render_job_upload_texture (job, texture, use_mipmap, &offscreen); gsk_gl_render_job_upload_texture (job, texture, use_mipmap, &offscreen);
@ -3396,7 +3396,7 @@ gsk_gl_render_job_visit_mask_node (GskGLRenderJob *job,
mask_offscreen.reset_clip = TRUE; mask_offscreen.reset_clip = TRUE;
mask_offscreen.do_not_cache = TRUE; mask_offscreen.do_not_cache = TRUE;
gsk_gl_render_job_set_modelview (job, gsk_transform_scale (NULL, fabs (job->scale_x), fabs (job->scale_y))); gsk_gl_render_job_set_modelview (job, gsk_transform_scale (NULL, fabsf (job->scale_x), fabsf (job->scale_y)));
/* TODO: We create 2 textures here as big as the mask node, but both /* TODO: We create 2 textures here as big as the mask node, but both
* nodes might be a lot smaller than that. * nodes might be a lot smaller than that.
@ -3664,8 +3664,8 @@ gsk_gl_render_job_visit_texture (GskGLRenderJob *job,
float scale_y = bounds->size.height / texture->height; float scale_y = bounds->size.height / texture->height;
gboolean use_mipmap; gboolean use_mipmap;
use_mipmap = (scale_x * fabs (job->scale_x)) < 0.5 || use_mipmap = (scale_x * fabsf (job->scale_x)) < 0.5 ||
(scale_y * fabs (job->scale_y)) < 0.5; (scale_y * fabsf (job->scale_y)) < 0.5;
if G_LIKELY (texture->width <= max_texture_size && if G_LIKELY (texture->width <= max_texture_size &&
texture->height <= max_texture_size) texture->height <= max_texture_size)

View File

@ -322,8 +322,8 @@ rect_round_to_pixels (const graphene_rect_t *src,
*dest = GRAPHENE_RECT_INIT ( *dest = GRAPHENE_RECT_INIT (
x * inv_xscale - pixel_offset->x, x * inv_xscale - pixel_offset->x,
y * inv_yscale - pixel_offset->y, y * inv_yscale - pixel_offset->y,
(ceil ((src->origin.x + pixel_offset->x + src->size.width) * xscale) - x) * inv_xscale, (ceilf ((src->origin.x + pixel_offset->x + src->size.width) * xscale) - x) * inv_xscale,
(ceil ((src->origin.y + pixel_offset->y + src->size.height) * yscale) - y) * inv_yscale); (ceilf ((src->origin.y + pixel_offset->y + src->size.height) * yscale) - y) * inv_yscale);
} }
static GskGpuImage * static GskGpuImage *
@ -338,8 +338,8 @@ gsk_gpu_node_processor_init_draw (GskGpuNodeProcessor *self,
area.x = 0; area.x = 0;
area.y = 0; area.y = 0;
area.width = ceil (graphene_vec2_get_x (scale) * viewport->size.width); area.width = ceilf (graphene_vec2_get_x (scale) * viewport->size.width);
area.height = ceil (graphene_vec2_get_y (scale) * viewport->size.height); area.height = ceilf (graphene_vec2_get_y (scale) * viewport->size.height);
image = gsk_gpu_device_create_offscreen_image (gsk_gpu_frame_get_device (frame), image = gsk_gpu_device_create_offscreen_image (gsk_gpu_frame_get_device (frame),
FALSE, FALSE,
@ -994,8 +994,8 @@ gsk_gpu_node_processor_blur_op (GskGpuNodeProcessor *self,
if (!gsk_rect_intersection (rect, &clip_rect, &intermediate_rect)) if (!gsk_rect_intersection (rect, &clip_rect, &intermediate_rect))
return; return;
width = ceil (graphene_vec2_get_x (&self->scale) * intermediate_rect.size.width); width = ceilf (graphene_vec2_get_x (&self->scale) * intermediate_rect.size.width);
height = ceil (graphene_vec2_get_y (&self->scale) * intermediate_rect.size.height); height = ceilf (graphene_vec2_get_y (&self->scale) * intermediate_rect.size.height);
intermediate = gsk_gpu_device_create_offscreen_image (gsk_gpu_frame_get_device (self->frame), intermediate = gsk_gpu_device_create_offscreen_image (gsk_gpu_frame_get_device (self->frame),
FALSE, FALSE,
@ -1814,10 +1814,10 @@ gsk_gpu_node_processor_add_color_node (GskGpuNodeProcessor *self,
if (shader_clip != GSK_GPU_SHADER_CLIP_NONE) if (shader_clip != GSK_GPU_SHADER_CLIP_NONE)
{ {
gsk_rounded_rect_get_largest_cover (&self->clip.rect, &clipped, &cover); gsk_rounded_rect_get_largest_cover (&self->clip.rect, &clipped, &cover);
int_clipped.x = ceil (cover.origin.x * scale_x); int_clipped.x = ceilf (cover.origin.x * scale_x);
int_clipped.y = ceil (cover.origin.y * scale_y); int_clipped.y = ceilf (cover.origin.y * scale_y);
int_clipped.width = floor ((cover.origin.x + cover.size.width) * scale_x) - int_clipped.x; int_clipped.width = floorf ((cover.origin.x + cover.size.width) * scale_x) - int_clipped.x;
int_clipped.height = floor ((cover.origin.y + cover.size.height) * scale_y) - int_clipped.y; int_clipped.height = floorf ((cover.origin.y + cover.size.height) * scale_y) - int_clipped.y;
if (int_clipped.width == 0 || int_clipped.height == 0) if (int_clipped.width == 0 || int_clipped.height == 0)
{ {
gsk_gpu_color_op (self->frame, gsk_gpu_color_op (self->frame,
@ -3015,8 +3015,8 @@ gsk_gpu_node_processor_add_glyph_node (GskGpuNodeProcessor *self,
&glyph_bounds, &glyph_bounds,
&glyph_offset); &glyph_offset);
graphene_rect_scale (&GRAPHENE_RECT_INIT (-glyph_bounds.origin.x, -glyph_bounds.origin.y, gsk_gpu_image_get_width (image), gsk_gpu_image_get_height (image)), inv_scale, inv_scale, &glyph_tex_rect); gsk_rect_scale (&GRAPHENE_RECT_INIT (-glyph_bounds.origin.x, -glyph_bounds.origin.y, gsk_gpu_image_get_width (image), gsk_gpu_image_get_height (image)), inv_scale, inv_scale, &glyph_tex_rect);
graphene_rect_scale (&GRAPHENE_RECT_INIT(0, 0, glyph_bounds.size.width, glyph_bounds.size.height), inv_scale, inv_scale, &glyph_bounds); gsk_rect_scale (&GRAPHENE_RECT_INIT(0, 0, glyph_bounds.size.width, glyph_bounds.size.height), inv_scale, inv_scale, &glyph_bounds);
glyph_offset = GRAPHENE_POINT_INIT (offset.x - glyph_offset.x * inv_scale + (float) glyphs[i].geometry.x_offset / PANGO_SCALE, glyph_offset = GRAPHENE_POINT_INIT (offset.x - glyph_offset.x * inv_scale + (float) glyphs[i].geometry.x_offset / PANGO_SCALE,
offset.y - glyph_offset.y * inv_scale + (float) glyphs[i].geometry.y_offset / PANGO_SCALE); offset.y - glyph_offset.y * inv_scale + (float) glyphs[i].geometry.y_offset / PANGO_SCALE);
descriptor = gsk_gpu_node_processor_add_image (self, image, GSK_GPU_SAMPLER_DEFAULT); descriptor = gsk_gpu_node_processor_add_image (self, image, GSK_GPU_SAMPLER_DEFAULT);

View File

@ -132,3 +132,20 @@ gsk_rect_round_larger (graphene_rect_t *rect)
ceil (rect->origin.y + rect->size.height) - y); ceil (rect->origin.y + rect->size.height) - y);
} }
static inline void
gsk_rect_scale (const graphene_rect_t *r,
float sx,
float sy,
graphene_rect_t *res)
{
if (G_UNLIKELY (sx < 0 || sy < 0))
{
graphene_rect_scale (r, sx, sy, res);
return;
}
res->origin.x = r->origin.x * sx;
res->origin.y = r->origin.y * sy;
res->size.width = r->size.width * sx;
res->size.height = r->size.height * sy;
}

View File

@ -311,8 +311,8 @@ gsk_rounded_rect_scale_affine (GskRoundedRect *dest,
graphene_rect_scale (&src->bounds, scale_x, scale_y, &dest->bounds); graphene_rect_scale (&src->bounds, scale_x, scale_y, &dest->bounds);
graphene_rect_offset (&dest->bounds, dx, dy); graphene_rect_offset (&dest->bounds, dx, dy);
scale_x = fabs (scale_x); scale_x = fabsf (scale_x);
scale_y = fabs (scale_y); scale_y = fabsf (scale_y);
for (guint i = 0; i < 4; i++) for (guint i = 0; i < 4; i++)
{ {

View File

@ -159,7 +159,7 @@
</object> </object>
</child> </child>
<child> <child>
<object class="GtkCheckButton" id="verboe"> <object class="GtkCheckButton" id="verbose">
<property name="label">Verbose</property> <property name="label">Verbose</property>
<signal name="toggled" handler="flag_toggled"/> <signal name="toggled" handler="flag_toggled"/>
</object> </object>