summaryrefslogtreecommitdiff
path: root/workspaces/main/shaders/particle_spray_compute.wgsl
diff options
context:
space:
mode:
Diffstat (limited to 'workspaces/main/shaders/particle_spray_compute.wgsl')
-rw-r--r--workspaces/main/shaders/particle_spray_compute.wgsl18
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;
}