summaryrefslogtreecommitdiff
path: root/assets/final/shaders/gaussian_blur.wgsl
diff options
context:
space:
mode:
authorskal <pascal.massimino@gmail.com>2026-02-08 17:43:44 +0100
committerskal <pascal.massimino@gmail.com>2026-02-08 17:43:44 +0100
commit4b23fdc63d422b31b6ad86d34218e7b66b462514 (patch)
tree028e4fec0d49a7a3a997bd446c9f1ce480ce787b /assets/final/shaders/gaussian_blur.wgsl
parent8296fe5180b979b9d1f32f6375b41f0e0a8a399d (diff)
feat(gpu): Add parameter-driven GaussianBlurEffect
Extends shader parametrization system to GaussianBlurEffect with strength parameter (Task #73 continued). Changes: - Added GaussianBlurParams struct (strength, default: 2.0f) - Added GaussianBlurUniforms with proper WGSL alignment (32 bytes) - Updated shader to use parameterized strength instead of hardcoded 2.0 - Extended seq_compiler to parse strength parameter - Updated demo.seq with 2 parameterized instances: * Line 38: strength=3.0 (stronger blur for particles) * Line 48: strength=1.5 (subtle blur) Technical details: - Backward-compatible default constructor maintained - Migrated from raw buffer to UniformBuffer<GaussianBlurUniforms> - Shader replaces 'let base_size = 2.0' with 'uniforms.strength' - Generated code creates GaussianBlurParams initialization Testing: - All 32/32 tests pass - Demo runs without errors - Generated code verified correct Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
Diffstat (limited to 'assets/final/shaders/gaussian_blur.wgsl')
-rw-r--r--assets/final/shaders/gaussian_blur.wgsl14
1 files changed, 8 insertions, 6 deletions
diff --git a/assets/final/shaders/gaussian_blur.wgsl b/assets/final/shaders/gaussian_blur.wgsl
index 7d39ac4..e848c6b 100644
--- a/assets/final/shaders/gaussian_blur.wgsl
+++ b/assets/final/shaders/gaussian_blur.wgsl
@@ -6,7 +6,10 @@ struct Uniforms {
beat: f32,
intensity: f32,
aspect_ratio: f32,
- resolution: vec2<f32>,
+ width: f32,
+ height: f32,
+ strength: f32,
+ _pad: f32,
};
@group(0) @binding(2) var<uniform> uniforms: Uniforms;
@@ -21,17 +24,16 @@ struct Uniforms {
}
@fragment fn fs_main(@builtin(position) p: vec4<f32>) -> @location(0) vec4<f32> {
- let uv = p.xy / uniforms.resolution;
+ let uv = p.xy / vec2<f32>(uniforms.width, uniforms.height);
var res = vec4<f32>(0.0);
- // Reduced base size + dramatic beat pulsation
- let base_size = 2.0;
+ // Parameterized strength + dramatic beat pulsation
let pulse = 0.5 + uniforms.intensity * 2.0; // Pulsate between 0.5x and 2.5x with beat
- let size = base_size * pulse;
+ let size = uniforms.strength * pulse;
for (var x: f32 = -2.0; x <= 2.0; x += 1.0) {
for (var y: f32 = -2.0; y <= 2.0; y += 1.0) {
- res += textureSample(txt, smplr, uv + vec2<f32>(x, y) * size / uniforms.resolution.x);
+ res += textureSample(txt, smplr, uv + vec2<f32>(x, y) * size / uniforms.width);
}
}
return res / 25.0;