diff options
| author | 2024-07-29 22:26:28 +0200 | |
|---|---|---|
| committer | 2024-07-29 22:26:28 +0200 | |
| commit | ddd48ca14f14210d92a17632a8fce467786c7494 (patch) | |
| tree | ace32d63f6cf1b8c811b44033fbf21f91b7603bd /wgpu | |
| parent | 6734d183594ebf89b8e6c030ea69d53ecb6b72db (diff) | |
| parent | 3eed34fa6f7ca9442c2bee8b93bb7465d6984259 (diff) | |
| download | iced-ddd48ca14f14210d92a17632a8fce467786c7494.tar.gz iced-ddd48ca14f14210d92a17632a8fce467786c7494.tar.bz2 iced-ddd48ca14f14210d92a17632a8fce467786c7494.zip | |
Merge pull request #2531 from iced-rs/fix/snap-quad-lines-in-wgpu
Snap `Quad` lines to the pixel grid in `iced_wgpu`
Diffstat (limited to 'wgpu')
| -rw-r--r-- | wgpu/src/shader/quad/solid.wgsl | 13 | 
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; | 
