mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-15 06:40:08 +00:00
gpu: respect pixel grid for Cairo rendering
Make sure fallbacks and fill/stroke masks use image surfaces with the same pixel grid as the target if possible. Fixes blurriness with some path renderings.
This commit is contained in:
parent
131ab11f5c
commit
5b3d14e15b
@ -1073,6 +1073,8 @@ gsk_gpu_node_processor_add_fallback_node (GskGpuNodeProcessor *self,
|
|||||||
if (!gsk_gpu_node_processor_clip_node_bounds (self, node, &clipped_bounds))
|
if (!gsk_gpu_node_processor_clip_node_bounds (self, node, &clipped_bounds))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
rect_round_to_pixels (&clipped_bounds, &self->scale, &self->offset, &clipped_bounds);
|
||||||
|
|
||||||
gsk_gpu_node_processor_sync_globals (self, 0);
|
gsk_gpu_node_processor_sync_globals (self, 0);
|
||||||
|
|
||||||
image = gsk_gpu_upload_cairo_op (self->frame,
|
image = gsk_gpu_upload_cairo_op (self->frame,
|
||||||
@ -3481,6 +3483,7 @@ gsk_gpu_node_processor_add_fill_node (GskGpuNodeProcessor *self,
|
|||||||
|
|
||||||
if (!gsk_gpu_node_processor_clip_node_bounds (self, node, &clip_bounds))
|
if (!gsk_gpu_node_processor_clip_node_bounds (self, node, &clip_bounds))
|
||||||
return;
|
return;
|
||||||
|
rect_round_to_pixels (&clip_bounds, &self->scale, &self->offset, &clip_bounds);
|
||||||
|
|
||||||
child = gsk_fill_node_get_child (node);
|
child = gsk_fill_node_get_child (node);
|
||||||
|
|
||||||
@ -3522,9 +3525,9 @@ gsk_gpu_node_processor_add_fill_node (GskGpuNodeProcessor *self,
|
|||||||
descriptors);
|
descriptors);
|
||||||
|
|
||||||
gsk_gpu_mask_op (self->frame,
|
gsk_gpu_mask_op (self->frame,
|
||||||
gsk_gpu_clip_get_shader_clip (&self->clip, &self->offset, &node->bounds),
|
gsk_gpu_clip_get_shader_clip (&self->clip, &self->offset, &clip_bounds),
|
||||||
self->desc,
|
self->desc,
|
||||||
&node->bounds,
|
&clip_bounds,
|
||||||
&self->offset,
|
&self->offset,
|
||||||
self->opacity,
|
self->opacity,
|
||||||
GSK_MASK_MODE_ALPHA,
|
GSK_MASK_MODE_ALPHA,
|
||||||
@ -3577,6 +3580,7 @@ gsk_gpu_node_processor_add_stroke_node (GskGpuNodeProcessor *self,
|
|||||||
|
|
||||||
if (!gsk_gpu_node_processor_clip_node_bounds (self, node, &clip_bounds))
|
if (!gsk_gpu_node_processor_clip_node_bounds (self, node, &clip_bounds))
|
||||||
return;
|
return;
|
||||||
|
rect_round_to_pixels (&clip_bounds, &self->scale, &self->offset, &clip_bounds);
|
||||||
|
|
||||||
child = gsk_stroke_node_get_child (node);
|
child = gsk_stroke_node_get_child (node);
|
||||||
|
|
||||||
@ -3618,9 +3622,9 @@ gsk_gpu_node_processor_add_stroke_node (GskGpuNodeProcessor *self,
|
|||||||
descriptors);
|
descriptors);
|
||||||
|
|
||||||
gsk_gpu_mask_op (self->frame,
|
gsk_gpu_mask_op (self->frame,
|
||||||
gsk_gpu_clip_get_shader_clip (&self->clip, &self->offset, &node->bounds),
|
gsk_gpu_clip_get_shader_clip (&self->clip, &self->offset, &clip_bounds),
|
||||||
self->desc,
|
self->desc,
|
||||||
&node->bounds,
|
&clip_bounds,
|
||||||
&self->offset,
|
&self->offset,
|
||||||
self->opacity,
|
self->opacity,
|
||||||
GSK_MASK_MODE_ALPHA,
|
GSK_MASK_MODE_ALPHA,
|
||||||
|
Loading…
Reference in New Issue
Block a user