summaryrefslogtreecommitdiffstats
path: root/wgpu
diff options
context:
space:
mode:
authorLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2024-07-29 21:26:03 +0200
committerLibravatar Héctor Ramón Jiménez <hector@hecrj.dev>2024-07-29 21:26:03 +0200
commit3eed34fa6f7ca9442c2bee8b93bb7465d6984259 (patch)
treeace32d63f6cf1b8c811b44033fbf21f91b7603bd /wgpu
parent6734d183594ebf89b8e6c030ea69d53ecb6b72db (diff)
downloadiced-3eed34fa6f7ca9442c2bee8b93bb7465d6984259.tar.gz
iced-3eed34fa6f7ca9442c2bee8b93bb7465d6984259.tar.bz2
iced-3eed34fa6f7ca9442c2bee8b93bb7465d6984259.zip
Snap `Quad` lines to the pixel grid in `iced_wgpu`
Diffstat (limited to 'wgpu')
-rw-r--r--wgpu/src/shader/quad/solid.wgsl13
1 files changed, 11 insertions, 2 deletions
diff --git a/wgpu/src/shader/quad/solid.wgsl b/wgpu/src/shader/quad/solid.wgsl
index d908afbc..8eee16bb 100644
--- a/wgpu/src/shader/quad/solid.wgsl
+++ b/wgpu/src/shader/quad/solid.wgsl
@@ -30,6 +30,15 @@ fn solid_vs_main(input: SolidVertexInput) -> SolidVertexOutput {
var pos: vec2<f32> = (input.pos + min(input.shadow_offset, vec2<f32>(0.0, 0.0)) - input.shadow_blur_radius) * globals.scale;
var scale: vec2<f32> = (input.scale + vec2<f32>(abs(input.shadow_offset.x), abs(input.shadow_offset.y)) + input.shadow_blur_radius * 2.0) * globals.scale;
+ var snap: vec2<f32> = vec2<f32>(0.0, 0.0);
+
+ if input.scale.x == 1.0 {
+ snap.x = round(pos.x) - pos.x;
+ }
+
+ if input.scale.y == 1.0 {
+ snap.y = round(pos.y) - pos.y;
+ }
var min_border_radius = min(input.scale.x, input.scale.y) * 0.5;
var border_radius: vec4<f32> = vec4<f32>(
@@ -43,13 +52,13 @@ fn solid_vs_main(input: SolidVertexInput) -> SolidVertexOutput {
vec4<f32>(scale.x + 1.0, 0.0, 0.0, 0.0),
vec4<f32>(0.0, scale.y + 1.0, 0.0, 0.0),
vec4<f32>(0.0, 0.0, 1.0, 0.0),
- vec4<f32>(pos - vec2<f32>(0.5, 0.5), 0.0, 1.0)
+ vec4<f32>(pos - vec2<f32>(0.5, 0.5) + snap, 0.0, 1.0)
);
out.position = globals.transform * transform * vec4<f32>(vertex_position(input.vertex_index), 0.0, 1.0);
out.color = input.color;
out.border_color = input.border_color;
- out.pos = input.pos * globals.scale;
+ out.pos = input.pos * globals.scale + snap;
out.scale = input.scale * globals.scale;
out.border_radius = border_radius * globals.scale;
out.border_width = input.border_width * globals.scale;