A game created for the Godot Wild Jam #21
Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.

104 lines
2.6KB

  1. shader_type canvas_item;
  2. uniform float rimWidth : hint_range(1.0, 3.0) = 2.0;
  3. uniform vec4 rim_color : hint_color;
  4. uniform vec4 cell_color : hint_color;
  5. uniform float fisheye_power = 2.0;
  6. uniform float wave_amp : hint_range(-1.0, 1.0) = 0.25;
  7. uniform float wave_freq : hint_range(0.0, 1.0) = 0.25;
  8. uniform float wave_scale :hint_range(0.0, 10.0) = 1.0;
  9. vec2 random2(vec2 p){
  10. return fract(sin(vec2(dot(p, vec2(127.1, 311.7)), dot(p, vec2(269.5, 183.3)))) * 43758.5453);
  11. }
  12. float ramp(float v, float f_min, float f_max){
  13. float res = (v - f_min) / (f_max - f_min);
  14. return max(0.0, min(res, 1.0));
  15. }
  16. float CellularNoise(vec2 vUV, float scale, float time){
  17. // Code modified from...
  18. // https://thebookofshaders.com/12/
  19. vec2 st = vUV * scale;
  20. //st.x = vres.x/vres.y;
  21. vec2 i_st = floor(st);
  22. vec2 f_st = fract(st);
  23. float min_dist = 1.0;
  24. for (int y = -1; y <= 1; y++){
  25. for (int x = -1; x <= 1; x++){
  26. vec2 neighbor = vec2(float(x), float(y));
  27. vec2 point = random2(i_st + neighbor);
  28. point = 0.5 + (0.5 * sin(time + (6.2831 * point)));
  29. float dist = length((neighbor + point) - f_st);
  30. min_dist = min(min_dist, dist);
  31. }
  32. }
  33. return min_dist;
  34. }
  35. vec2 fisheye(vec2 p) {
  36. // Function borrowed and slightly modified from...
  37. // https://gist.github.com/henriquelalves/989fdd72e10c90091188
  38. p *= 2.0;
  39. p -= vec2(1.0, 1.0);
  40. if (length(p) >= 1.5){return p;}
  41. //return p;
  42. if(p.x > 0.0){
  43. float angle = p.y / p.x;
  44. float theta = atan(angle);
  45. float radius = length(p);
  46. radius = pow(radius, fisheye_power);
  47. p.x = radius * cos(theta);
  48. p.y = radius * sin(theta);
  49. } else {
  50. float angle = p.y / p.x;
  51. float theta = atan(angle);
  52. float radius = length(p);
  53. radius = pow(radius, fisheye_power);
  54. p.y = radius * sin(-theta);
  55. p.x = radius * cos(theta);
  56. p.x = - p.x;
  57. }
  58. return 0.5 * (p + vec2(1.0,1.0));
  59. }
  60. vec2 wavey(vec2 p, float time) {
  61. float dx = wave_amp * sin(wave_freq * (p.y * wave_scale) * time);
  62. float dy = wave_amp * cos(wave_freq * (p.x * wave_scale) * time);
  63. //return vec2(dx, dy);
  64. return vec2(p.x + dx, p.y + dy);
  65. }
  66. void fragment(){
  67. float n = ramp(CellularNoise(wavey(fisheye(UV.xy), TIME), 5.0, TIME), 0.2, 0.9);
  68. float rim = length(vec2(0.5, 0.5) - (UV.xy));
  69. float mask = 1.0;
  70. if (rim > 0.5){
  71. rim = 0.0;
  72. mask = 0.0;
  73. }
  74. vec4 r_color = rim_color;
  75. rim = ramp(pow(rim, 4.0 - rimWidth), 0.125, 0.5);
  76. vec4 color = vec4(((cell_color.rgb * 0.5) + (texture(SCREEN_TEXTURE, wavey(SCREEN_UV, TIME*2.0)).rgb * 0.5)) * n, n);
  77. if (mask > 0.0){
  78. if (rim >= 0.9 || rim > n){
  79. color = color + vec4(rim_color.rgb * rim, rim);
  80. }
  81. } else {
  82. color.a = 0.0;
  83. }
  84. COLOR = color;
  85. }