blob: 551d5225beff2269c2ffff5918113cb2b0277fac (
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: vec2<f32>,
radius: f32,
_pad: f32,
};
@group(0) @binding(3) var<uniform> params: GaussianBlurParams;
@fragment fn fs_main(in: VertexOutput) -> @location(0) vec4<f32> {
let texel_size = 1.0 / uniforms.resolution;
let offset = params.direction * texel_size;
var color = vec4<f32>(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;
}
|