summaryrefslogtreecommitdiff
path: root/assets
diff options
context:
space:
mode:
Diffstat (limited to 'assets')
-rw-r--r--assets/demo.seq4
-rw-r--r--assets/final/shaders/gaussian_blur.wgsl14
2 files changed, 10 insertions, 8 deletions
diff --git a/assets/demo.seq b/assets/demo.seq
index 8f84c30..cada95e 100644
--- a/assets/demo.seq
+++ b/assets/demo.seq
@@ -35,7 +35,7 @@ SEQUENCE 4b 0
SEQUENCE 6b 1
EFFECT + ParticleSprayEffect 0 4 # Priority 0 (spray particles)
EFFECT + ParticlesEffect 0 4 # Priority 1
- EFFECT = GaussianBlurEffect 0 8 # Priority 1 (same layer)
+ EFFECT = GaussianBlurEffect 0 8 strength=3.0 # Priority 1 (stronger blur)
SEQUENCE 7b 0
EFFECT + HeptagonEffect 0.0 .2 # Priority 0
@@ -46,7 +46,7 @@ SEQUENCE 7b 0
SEQUENCE 8b 3
EFFECT + ThemeModulationEffect 0 4 # Priority 0
EFFECT = HeptagonEffect 0.0 4.0 # Priority 0 (same layer)
- EFFECT + GaussianBlurEffect 0 8 # Priority 1
+ EFFECT + GaussianBlurEffect 0 8 strength=1.5 # Priority 1 (subtle blur)
EFFECT + ChromaAberrationEffect 0 6 offset=0.03 angle=0.785 # Priority 2 (diagonal, stronger)
EFFECT + SolarizeEffect 0 10 # Priority 3
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;