animate_shader.wgsl 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. // The time since startup data is in the globals binding which is part of the mesh_view_bindings import
  2. #import bevy_pbr::{
  3. mesh_view_bindings::globals,
  4. forward_io::VertexOutput,
  5. }
  6. fn oklab_to_linear_srgb(c: vec3<f32>) -> vec3<f32> {
  7. let L = c.x;
  8. let a = c.y;
  9. let b = c.z;
  10. let l_ = L + 0.3963377774 * a + 0.2158037573 * b;
  11. let m_ = L - 0.1055613458 * a - 0.0638541728 * b;
  12. let s_ = L - 0.0894841775 * a - 1.2914855480 * b;
  13. let l = l_ * l_ * l_;
  14. let m = m_ * m_ * m_;
  15. let s = s_ * s_ * s_;
  16. return vec3<f32>(
  17. 4.0767416621 * l - 3.3077115913 * m + 0.2309699292 * s,
  18. -1.2684380046 * l + 2.6097574011 * m - 0.3413193965 * s,
  19. -0.0041960863 * l - 0.7034186147 * m + 1.7076147010 * s,
  20. );
  21. }
  22. @fragment
  23. fn fragment(in: VertexOutput) -> @location(0) vec4<f32> {
  24. let speed = 2.0;
  25. // The globals binding contains various global values like time
  26. // which is the time since startup in seconds
  27. let t_1 = sin(globals.time * speed) * 0.5 + 0.5;
  28. let t_2 = cos(globals.time * speed);
  29. let distance_to_center = distance(in.uv, vec2<f32>(0.5)) * 1.4;
  30. // blending is done in a perceptual color space: https://bottosson.github.io/posts/oklab/
  31. let red = vec3<f32>(0.627955, 0.224863, 0.125846);
  32. let green = vec3<f32>(0.86644, -0.233887, 0.179498);
  33. let blue = vec3<f32>(0.701674, 0.274566, -0.169156);
  34. let white = vec3<f32>(1.0, 0.0, 0.0);
  35. let mixed = mix(mix(red, blue, t_1), mix(green, white, t_2), distance_to_center);
  36. return vec4<f32>(oklab_to_linear_srgb(mixed), 1.0);
  37. }