Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.
 
 
 

200 řádky
5.5 KiB

  1. [vert.glsl]
  2. #version 120
  3. attribute vec3 in_Position;
  4. attribute vec3 in_Normal;
  5. attribute vec4 in_Color;
  6. uniform mat4 u_modelview;
  7. uniform mat4 u_view;
  8. uniform mat4 u_projection;
  9. uniform mat3 u_normalmat;
  10. varying vec4 pass_Vertex; /* View space */
  11. varying vec3 pass_TNormal;
  12. varying vec4 pass_Color;
  13. void main(void)
  14. {
  15. vec4 vertex = u_modelview * vec4(in_Position, 1.0);
  16. vec3 tnorm = normalize(u_normalmat * in_Normal);
  17. pass_Vertex = vertex;
  18. pass_TNormal = tnorm;
  19. pass_Color = in_Color;
  20. gl_Position = u_projection * vertex;
  21. }
  22. [frag.glsl]
  23. #version 120
  24. #if defined GL_ES
  25. precision highp float;
  26. #endif
  27. uniform float in_Damage;
  28. uniform mat4 u_view;
  29. uniform mat4 u_inv_view;
  30. uniform vec4 u_lights[8 * 2];
  31. varying vec4 pass_Vertex; /* View space */
  32. varying vec3 pass_TNormal;
  33. varying vec4 pass_Color;
  34. #if 0
  35. //Cos(45) = 0.70710678118
  36. //1.0 - Cos(45) = 0.29289321881
  37. const float cos_45 = 0.70710678118;
  38. const float inv_cos_45 = 0.29289321881;
  39. //Cube Light
  40. vec4 in_Light3_Pos = vec4(-10.0, 10.0, 5.0, 1.0);
  41. vec3 in_Light3_Size_Inner = vec3(3.0, 1.0, 3.0);
  42. vec3 in_Light3_Size_Outer = vec3(15.0, 15.0, 15.0);
  43. vec3 in_Light3_diffuse = vec3(0.4, 1.0, 0.4);
  44. #endif
  45. void main(void)
  46. {
  47. vec3 TNormal = pass_TNormal;
  48. /* Material properties */
  49. vec3 specular_reflect = vec3(0.8, 0.75, 0.4);
  50. float specular_power = 60.0;
  51. /* World properties */
  52. vec3 ambient = vec3(0.1, 0.1, 0.1);
  53. vec3 specular = vec3(0.0, 0.0, 0.0);
  54. vec3 diffuse = vec3(0.0, 0.0, 0.0);
  55. /* Light precalculations */
  56. vec3 v = normalize(-pass_Vertex.xyz);
  57. /* Apply lighting */
  58. for (int i = 0; i < 8; i++)
  59. {
  60. vec4 pos = u_lights[i * 2];
  61. vec4 color = u_lights[i * 2 + 1];
  62. vec3 s, r, p;
  63. p = (u_view * pos).xyz;
  64. if (pos.w > 0.0)
  65. {
  66. /* Point light -- no attenuation yet */
  67. s = normalize(p - pass_Vertex.xyz);
  68. }
  69. else
  70. {
  71. /* Directional light */
  72. s = normalize(-p);
  73. }
  74. r = reflect(-s, TNormal);
  75. float sdotn = max(dot(s, TNormal), 0.0);
  76. diffuse += color.xyz * sdotn;
  77. if (sdotn > 0.0)
  78. specular += color.xyz * specular_reflect
  79. * pow(max(dot(r, v), 0.0), specular_power);
  80. }
  81. #if 0
  82. //Light calculation for cube light
  83. vec3 specular_color = vec3(1.0, 1.0, 0.6);
  84. vec3 Local_Vertex = (u_inv_view * pass_Vertex).xyz - (in_Light3_Pos).xyz;
  85. vec3 Proj_Vertex = clamp(Local_Vertex.xyz, -in_Light3_Size_Inner, in_Light3_Size_Inner);
  86. vec3 new_LightDir = Local_Vertex - Proj_Vertex;
  87. vec3 light_radius = max(vec3(0.0,0.0,0.0), vec3(1.0,1.0,1.0) - abs(new_LightDir / in_Light3_Size_Outer));
  88. float light_radius_mod = min(light_radius.x, min(light_radius.y, light_radius.z));
  89. if (length(new_LightDir) == 0.0)
  90. sdotn = 1.0;
  91. else
  92. {
  93. new_LightDir = normalize((u_view * vec4(Proj_Vertex + in_Light3_Pos.xyz,1.0)).xyz - pass_Vertex.xyz);
  94. sdotn = max(dot(new_LightDir, TNormal), 0.0);
  95. r = reflect(-new_LightDir, TNormal);
  96. if (sdotn > 0.0 && light_radius_mod > 0.0)
  97. specular += specular_color * min(specular_reflect, light_radius_mod)
  98. * pow(max(dot(r, v), 0.0), specular_power);
  99. }
  100. diffuse += in_Light3_diffuse * min(sdotn, light_radius_mod);
  101. //----------
  102. #endif
  103. vec3 light = ambient + diffuse + specular;
  104. vec4 real_color = mix(pass_Color, vec4(1.2, 1.2, 1.2, 1.0), in_Damage);
  105. gl_FragColor = real_color * vec4(light, 1.0);
  106. }
  107. [vert.hlsl]
  108. void main(float3 in_Vertex : POSITION,
  109. float3 in_Normal : NORMAL,
  110. float4 in_Color : COLOR,
  111. uniform float4x4 u_modelview,
  112. uniform float4x4 u_projection,
  113. uniform float3x3 u_normalmat,
  114. out float4 pass_Vertex : TEXCOORD0,
  115. out float3 pass_TNormal : TEXCOORD1,
  116. out float4 pass_Color : COLOR,
  117. out float4 out_Position : POSITION)
  118. {
  119. float4 eye = mul(u_modelview, float4(in_Vertex, 1.0));
  120. float3 tnorm = normalize(mul(u_normalmat, in_Normal));
  121. pass_Vertex = eye;
  122. pass_TNormal = tnorm;
  123. #ifdef _XBOX
  124. pass_Color = in_Color.abgr;
  125. #else
  126. pass_Color = in_Color;
  127. #endif
  128. out_Position = mul(u_projection, eye);
  129. }
  130. [frag.hlsl]
  131. void main(float4 pass_Vertex : TEXCOORD0,
  132. float3 pass_TNormal : TEXCOORD1,
  133. float4 pass_Color : COLOR,
  134. uniform float in_Damage,
  135. out float4 out_FragColor : COLOR)
  136. {
  137. float3 in_LightDir = float3(0.3, 0.3, 0.7);
  138. /* Material properties */
  139. float3 specular_reflect = float3(0.8, 0.75, 0.4);
  140. float specular_power = 60.0;
  141. /* World properties */
  142. float ambient_mul = 0.5;
  143. float3 ambient_color = float3(0.25, 0.2, 0.35);
  144. float3 diffuse_color = float3(1.0, 1.0, 0.6);
  145. float3 specular_color = float3(1.0, 1.0, 0.6);
  146. float3 s = normalize(in_LightDir); /* normalize(pass_Vertex - lightpos); */
  147. float3 v = normalize(-pass_Vertex.xyz);
  148. float3 r = reflect(-s, pass_TNormal);
  149. float3 ambient = ambient_color;
  150. float sdotn = max(dot(s, pass_TNormal), 0.0);
  151. float3 diffuse = diffuse_color * sdotn;
  152. float3 specular = float3(0.0, 0.0, 0.0);
  153. if (sdotn > 0.0)
  154. specular = specular_color * specular_reflect
  155. * pow(max(dot(r, v), 0.0), specular_power);
  156. float3 light = ambient + diffuse + specular;
  157. float4 real_color = in_Damage * float4(1.2, 1.2, 1.2, 1.0)
  158. + (1.0 - in_Damage) * pass_Color;
  159. out_FragColor = real_color * float4(light, 1.0);
  160. }