233 wiersze
5.4 KiB

  1. -- GLSL.Vert --
  2. #version 120
  3. uniform float u_Time;
  4. attribute vec2 in_Position;
  5. varying vec2 pass_Position;
  6. varying mat2 pass_Rotation;
  7. varying vec3 water[4];
  8. varying vec3 fire[4];
  9. float mod289(float x)
  10. {
  11. return x - floor(x * (1.0 / 289.0)) * 289.0;
  12. }
  13. void main(void)
  14. {
  15. mat3 r = mat3(0.36, 0.48, -0.8, -0.8, 0.60, 0.0, 0.48, 0.64, 0.60);
  16. vec3 p_pos = r * vec3(in_Position * vec2(16.0, 9.0), 0.0);
  17. vec3 p_time = r * vec3(0.0, 0.0, u_Time * 2.0);
  18. /* Noise sampling points for water */
  19. water[0] = p_pos / 2.0 + p_time;
  20. water[1] = p_pos / 4.0 + p_time;
  21. water[2] = p_pos / 8.0 + p_time;
  22. water[3] = p_pos / 16.0 + p_time;
  23. /* Noise sampling points for fire */
  24. p_pos = 16.0 * p_pos - r * vec3(0.0, mod289(u_Time) * 128.0, 0.0);
  25. fire[0] = p_pos / 2.0 + p_time;
  26. fire[1] = p_pos / 4.0 + p_time;
  27. fire[2] = p_pos / 8.0 + p_time;
  28. fire[3] = p_pos / 16.0 + p_time;
  29. pass_Position = in_Position;
  30. pass_Rotation = mat2(cos(u_Time), sin(u_Time), -sin(u_Time), cos(u_Time));
  31. gl_Position = vec4(in_Position, 0.0, 1.0);
  32. }
  33. -- GLSL.Frag --
  34. #version 120
  35. uniform float u_Time;
  36. varying vec2 pass_Position;
  37. varying mat2 pass_Rotation;
  38. varying vec3 water[4];
  39. varying vec3 fire[4];
  40. vec4 mod289(vec4 x)
  41. {
  42. return x - floor(x * (1.0 / 289.0)) * 289.0;
  43. }
  44. vec4 perm(vec4 x)
  45. {
  46. return mod289(((x * 34.0) + 1.0) * x);
  47. }
  48. float noise3d(vec3 p)
  49. {
  50. vec3 a = floor(p);
  51. vec3 d = p - a;
  52. d = d * d * (3.0 - 2.0 * d);
  53. vec4 b = a.xxyy + vec4(0.0, 1.0, 0.0, 1.0);
  54. vec4 k1 = perm(b.xyxy);
  55. vec4 k2 = perm(k1.xyxy + b.zzww);
  56. vec4 c = k2 + a.zzzz;
  57. vec4 k3 = perm(c);
  58. vec4 k4 = perm(c + 1.0);
  59. vec4 o1 = fract(k3 * (1.0 / 41.0));
  60. vec4 o2 = fract(k4 * (1.0 / 41.0));
  61. vec4 o3 = o2 * d.z + o1 * (1.0 - d.z);
  62. vec2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);
  63. return o4.y * d.y + o4.x * (1.0 - d.y);
  64. }
  65. void main(void)
  66. {
  67. vec2 tmp = pass_Rotation * pass_Position;
  68. float test = tmp.x * tmp.y + 0.75 * sin(3.0 * u_Time);
  69. vec3 points[4] = (test > 0.0) ? fire : water;
  70. vec4 n = vec4(noise3d(points[0]),
  71. noise3d(points[1]),
  72. noise3d(points[2]),
  73. noise3d(points[3]));
  74. vec4 color;
  75. if (test > 0.0)
  76. {
  77. float p = dot(n, vec4(0.125, 0.125, 0.25, 0.5));
  78. /* Fade out by adding [-.5,.5] */
  79. p -= pass_Position.y * 0.8 + 0.25;
  80. p = max(p, 0.0);
  81. p = min(p, 1.0);
  82. float q = p * p * (3.0 - 2.0 * p);
  83. float r = q * q * (3.0 - 2.0 * q);
  84. color = vec4(min(q * 2.0, 1.0),
  85. max(r * 1.5 - 0.5, 0.0),
  86. max(q * 8.0 - 7.3, 0.0),
  87. 1.0);
  88. }
  89. else
  90. {
  91. float p = dot(abs(2.0 * n - 1.0),
  92. vec4(0.5, 0.25, 0.125, 0.125));
  93. float q = sqrt(p);
  94. color = vec4(1.0 - q,
  95. 1.0 - 0.5 * q,
  96. 1.0,
  97. 1.0);
  98. }
  99. gl_FragColor = color;
  100. }
  101. -- HLSL.Vert --
  102. void main(float2 in_Position : POSITION,
  103. uniform float2 u_WinSize,
  104. out float4 out_Position : POSITION,
  105. out float2 pass_Position : TEXCOORD0)
  106. {
  107. //pass_Position = in_Position * u_WinSize;
  108. pass_Position = in_Position * float2(1280.0, 720.0);
  109. out_Position = float4(in_Position, 0.0, 1.0);
  110. }
  111. -- HLSL.Frag --
  112. float4 mod289(float4 x)
  113. {
  114. return x - floor(x * (1.0 / 289.0)) * 289.0;
  115. }
  116. float4 perm(float4 x)
  117. {
  118. return mod289(((x * 34.0) + 1.0) * x);
  119. }
  120. float noise3d(float3 p)
  121. {
  122. float3x3 r = float3x3(0.36, 0.48, -0.8, -0.8, 0.60, 0.0, 0.48, 0.64, 0.60);
  123. p = mul(r, p);
  124. float3 a = floor(p);
  125. float3 d = p - a;
  126. d = d * d * (3.0 - 2.0 * d);
  127. float4 b = a.xxyy + float4(0.0, 1.0, 0.0, 1.0);
  128. float4 k1 = perm(b.xyxy);
  129. float4 k2 = perm(k1.xyxy + b.zzww);
  130. float4 c = k2 + a.zzzz;
  131. float4 k3 = perm(c);
  132. float4 k4 = perm(c + 1.0);
  133. float4 o1 = frac(k3 * (1.0 / 41.0));
  134. float4 o2 = frac(k4 * (1.0 / 41.0));
  135. float4 o3 = o2 * d.z + o1 * (1.0 - d.z);
  136. float2 o4 = o3.yw * d.x + o3.xz * (1.0 - d.x);
  137. return o4.y * d.y + o4.x * (1.0 - d.y);
  138. }
  139. void main(in float2 pass_Position : TEXCOORD0,
  140. uniform float u_Time,
  141. out float4 out_FragColor : COLOR)
  142. {
  143. float2 xy = pass_Position;
  144. float z = u_Time * 2.0;
  145. float tx = pass_Position.x * cos(u_Time) - pass_Position.y * sin(u_Time);
  146. float ty = pass_Position.x * sin(u_Time) + pass_Position.y * cos(u_Time);
  147. if (tx * ty > 0.0)
  148. xy.y -= z * 200.0;
  149. float p1 = noise3d(float3(xy / 80.0, z));
  150. float p2 = noise3d(float3(xy / 40.0, z));
  151. float p3 = noise3d(float3(xy / 20.0, z));
  152. float p4 = noise3d(float3(xy / 10.0, z));
  153. float4 color;
  154. if (tx * ty > 0.0)
  155. {
  156. float p = 0.5 * p1 + 0.25 * p2 + 0.125 * (p3 + p4);
  157. /* Scroll by adding [-.5,.5] */
  158. p -= pass_Position.y / 1440.0;
  159. p = max(p, 0.0);
  160. p = min(p, 1.0);
  161. float q = p * p * (3.0 - 2.0 * p);
  162. float r = q * q * (3.0 - 2.0 * q);
  163. color = float4(min(q * 2.0, 1.0),
  164. max(r * 1.5 - 0.5, 0.0),
  165. max(q * 8.0 - 7.3, 0.0),
  166. 1.0);
  167. }
  168. else
  169. {
  170. float p = 0.5 * p1 + 0.25 * p2 + 0.125 * (p3 + p4);
  171. float q = p * p * (3.0 - 2.0 * p);
  172. float r = q * q * (3.0 - 2.0 * q);
  173. color = float4(1.0 - q,
  174. 1.0 - 0.5 * r,
  175. 1.0,
  176. 1.0);
  177. }
  178. out_FragColor = color;
  179. }