diff options
author | 2024-03-29 20:18:32 +0900 | |
---|---|---|
committer | 2024-03-29 20:18:32 +0900 | |
commit | b7c9576e95da04ab0bc7d5046a2e68b269279e8c (patch) | |
tree | 88c3c225c58051c91234285f2a74d9d64c21a607 /wgpu/src/shader | |
parent | 19afc66cadfc7ea230d4d749b0d7b0197e29cf93 (diff) | |
parent | 5071e3d231699f67347a11b829cc8c9e50e54370 (diff) | |
download | iced-b7c9576e95da04ab0bc7d5046a2e68b269279e8c.tar.gz iced-b7c9576e95da04ab0bc7d5046a2e68b269279e8c.tar.bz2 iced-b7c9576e95da04ab0bc7d5046a2e68b269279e8c.zip |
Merge branch 'iced-rs:master' into viewer_content_fit
Diffstat (limited to 'wgpu/src/shader')
-rw-r--r-- | wgpu/src/shader/quad/solid.wgsl | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/wgpu/src/shader/quad/solid.wgsl b/wgpu/src/shader/quad/solid.wgsl index 1274f814..d908afbc 100644 --- a/wgpu/src/shader/quad/solid.wgsl +++ b/wgpu/src/shader/quad/solid.wgsl @@ -107,13 +107,19 @@ fn solid_fs_main( let quad_color = vec4<f32>(mixed_color.x, mixed_color.y, mixed_color.z, mixed_color.w * radius_alpha); if input.shadow_color.a > 0.0 { - let shadow_distance = rounded_box_sdf(input.position.xy - input.pos - input.shadow_offset - (input.scale / 2.0), input.scale / 2.0, border_radius); + let shadow_radius = select_border_radius( + input.border_radius, + input.position.xy - input.shadow_offset, + (input.pos + input.scale * 0.5).xy + ); + let shadow_distance = max(rounded_box_sdf(input.position.xy - input.pos - input.shadow_offset - (input.scale / 2.0), input.scale / 2.0, shadow_radius), 0.); + let shadow_alpha = 1.0 - smoothstep(-input.shadow_blur_radius, input.shadow_blur_radius, shadow_distance); let shadow_color = input.shadow_color; - let base_color = select( + let base_color = mix( vec4<f32>(shadow_color.x, shadow_color.y, shadow_color.z, 0.0), quad_color, - quad_color.a > 0.0 + quad_color.a ); return mix(base_color, shadow_color, (1.0 - radius_alpha) * shadow_alpha); |