diff options
Diffstat (limited to 'workspaces/main/shaders/particle_spray_compute.wgsl')
| -rw-r--r-- | workspaces/main/shaders/particle_spray_compute.wgsl | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/workspaces/main/shaders/particle_spray_compute.wgsl b/workspaces/main/shaders/particle_spray_compute.wgsl index 4b6e48f..7bdae88 100644 --- a/workspaces/main/shaders/particle_spray_compute.wgsl +++ b/workspaces/main/shaders/particle_spray_compute.wgsl @@ -1,8 +1,8 @@ struct Particle { - pos: vec4<f32>, - vel: vec4<f32>, - rot: vec4<f32>, - color: vec4<f32>, + pos: vec4f, + vel: vec4f, + rot: vec4f, + color: vec4f, }; #include "common_uniforms" @@ -15,7 +15,7 @@ fn hash(p: f32) -> f32 { } @compute @workgroup_size(64) -fn main(@builtin(global_invocation_id) id: vec3<u32>) { +fn main(@builtin(global_invocation_id) id: vec3u) { let i = id.x; if (i >= arrayLength(&particles)) { return; @@ -24,12 +24,12 @@ fn main(@builtin(global_invocation_id) id: vec3<u32>) { if (p.pos.w <= 0.0) { let r = hash(f32(i) + uniforms.time); let angle = r * 6.28318; - p.pos = vec4<f32>(0.0, 0.0, 0.0, 1.0); - p.vel = vec4<f32>(cos(angle), sin(angle), 0.0, 0.0) * (0.5 + hash(r) * 0.5) * (1.0 + uniforms.audio_intensity * 2.0); - p.color = vec4<f32>(hash(r + 0.1), hash(r + 0.2), 1.0, 1.0); + p.pos = vec4f(0.0, 0.0, 0.0, 1.0); + p.vel = vec4f(cos(angle), sin(angle), 0.0, 0.0) * (0.5 + hash(r) * 0.5) * (1.0 + uniforms.audio_intensity * 2.0); + p.color = vec4f(hash(r + 0.1), hash(r + 0.2), 1.0, 1.0); } let new_pos = p.pos.xyz + p.vel.xyz * 0.016; - p.pos = vec4<f32>(new_pos, p.pos.w - 0.01 * (1.0 + uniforms.beat_phase)); + p.pos = vec4f(new_pos, p.pos.w - 0.01 * (1.0 + uniforms.beat_phase)); p.vel.y = p.vel.y - 0.01; particles[i] = p; } |
