summaryrefslogtreecommitdiff
path: root/src/shaders/gaussian_blur.wgsl
blob: 7f85719ca8df4c7b48e3740a52fa2284d72c9eed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// Gaussian blur shader for Sequence v2
#include "sequence_uniforms"
#include "render/fullscreen_uv_vs"  // <- VertexOutput + vs_main

@group(0) @binding(0) var input_sampler: sampler;
@group(0) @binding(1) var input_texture: texture_2d<f32>;
@group(0) @binding(2) var<uniform> uniforms: UniformsSequenceParams;

struct GaussianBlurParams {
    direction: vec2f,
    radius: f32,
    _pad: f32,
};
@group(0) @binding(3) var<uniform> params: GaussianBlurParams;

@fragment fn fs_main(in: VertexOutput) -> @location(0) vec4f {
    let texel_size = 1.0 / uniforms.resolution;
    let offset = params.direction * texel_size;

    var color = vec4f(0.0);
    let kernel_size = i32(params.radius);
    var weight_sum = 0.0;

    for (var i = -kernel_size; i <= kernel_size; i++) {
        let sample_offset = f32(i) * offset;
        let weight = exp(-f32(i * i) / (2.0 * params.radius * params.radius));
        color += textureSample(input_texture, input_sampler, in.uv + sample_offset) * weight;
        weight_sum += weight;
    }

    return color / weight_sum;
}