xray_composite.shader 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. [shaders]
  2. vertex =
  3. uniform highp mat4 u_modelViewProjectionMatrix;
  4. attribute highp vec4 a_vertex;
  5. attribute highp vec2 a_uvs;
  6. varying highp vec2 v_uvs;
  7. void main()
  8. {
  9. gl_Position = u_modelViewProjectionMatrix * a_vertex;
  10. v_uvs = a_uvs;
  11. }
  12. fragment =
  13. #ifdef GL_ES
  14. #ifdef GL_FRAGMENT_PRECISION_HIGH
  15. precision highp float;
  16. #else
  17. precision mediump float;
  18. #endif // GL_FRAGMENT_PRECISION_HIGH
  19. #endif // GL_ES
  20. uniform sampler2D u_layer0; //Default pass.
  21. uniform sampler2D u_layer1; //Selection pass.
  22. uniform sampler2D u_layer2; //X-ray pass.
  23. uniform vec2 u_offset[9];
  24. uniform float u_outline_strength;
  25. uniform vec4 u_outline_color;
  26. uniform vec4 u_error_color;
  27. uniform vec4 u_background_color;
  28. const vec3 x_axis = vec3(1.0, 0.0, 0.0);
  29. const vec3 y_axis = vec3(0.0, 1.0, 0.0);
  30. const vec3 z_axis = vec3(0.0, 0.0, 1.0);
  31. varying vec2 v_uvs;
  32. float kernel[9];
  33. void main()
  34. {
  35. kernel[0] = 0.0; kernel[1] = 1.0; kernel[2] = 0.0;
  36. kernel[3] = 1.0; kernel[4] = -4.0; kernel[5] = 1.0;
  37. kernel[6] = 0.0; kernel[7] = 1.0; kernel[8] = 0.0;
  38. vec4 result = u_background_color;
  39. vec4 layer0 = texture2D(u_layer0, v_uvs);
  40. result = layer0 * layer0.a + result * (1.0 - layer0.a);
  41. float intersection_count = (texture2D(u_layer2, v_uvs).r * 255.0) / 5.0;
  42. if(mod(intersection_count, 2.0) >= 1.0)
  43. {
  44. result = u_error_color;
  45. }
  46. vec4 sum = vec4(0.0);
  47. for (int i = 0; i < 9; i++)
  48. {
  49. vec4 color = vec4(texture2D(u_layer1, v_uvs.xy + u_offset[i]).a);
  50. sum += color * (kernel[i] / u_outline_strength);
  51. }
  52. vec4 layer1 = texture2D(u_layer1, v_uvs);
  53. if((layer1.rgb == x_axis || layer1.rgb == y_axis || layer1.rgb == z_axis))
  54. {
  55. gl_FragColor = result;
  56. }
  57. else
  58. {
  59. gl_FragColor = mix(result, u_outline_color, abs(sum.a));
  60. }
  61. gl_FragColor.a = gl_FragColor.a > 0.5 ? 1.0 : 0.0;
  62. }
  63. vertex41core =
  64. #version 410
  65. uniform highp mat4 u_modelViewProjectionMatrix;
  66. in highp vec4 a_vertex;
  67. in highp vec2 a_uvs;
  68. out highp vec2 v_uvs;
  69. void main()
  70. {
  71. gl_Position = u_modelViewProjectionMatrix * a_vertex;
  72. v_uvs = a_uvs;
  73. }
  74. fragment41core =
  75. #version 410
  76. uniform sampler2D u_layer0; //Default pass.
  77. uniform sampler2D u_layer1; //Selection pass.
  78. uniform sampler2D u_layer2; //X-ray pass.
  79. uniform vec2 u_offset[9];
  80. uniform float u_outline_strength;
  81. uniform vec4 u_outline_color;
  82. uniform vec4 u_error_color;
  83. uniform vec4 u_background_color;
  84. const vec3 x_axis = vec3(1.0, 0.0, 0.0);
  85. const vec3 y_axis = vec3(0.0, 1.0, 0.0);
  86. const vec3 z_axis = vec3(0.0, 0.0, 1.0);
  87. in vec2 v_uvs;
  88. out vec4 frag_color;
  89. float kernel[9];
  90. void main()
  91. {
  92. kernel[0] = 0.0; kernel[1] = 1.0; kernel[2] = 0.0;
  93. kernel[3] = 1.0; kernel[4] = -4.0; kernel[5] = 1.0;
  94. kernel[6] = 0.0; kernel[7] = 1.0; kernel[8] = 0.0;
  95. vec4 result = u_background_color;
  96. vec4 layer0 = texture(u_layer0, v_uvs);
  97. result = layer0 * layer0.a + result * (1.0 - layer0.a);
  98. float intersection_count = (texture(u_layer2, v_uvs).r * 255.0) / 5.0;
  99. if(mod(intersection_count, 2.0) >= 1.0)
  100. {
  101. result = u_error_color;
  102. }
  103. vec4 sum = vec4(0.0);
  104. for (int i = 0; i < 9; i++)
  105. {
  106. vec4 color = vec4(texture(u_layer1, v_uvs.xy + u_offset[i]).a);
  107. sum += color * (kernel[i] / u_outline_strength);
  108. }
  109. vec4 layer1 = texture(u_layer1, v_uvs);
  110. if((layer1.rgb == x_axis || layer1.rgb == y_axis || layer1.rgb == z_axis))
  111. {
  112. frag_color = result;
  113. }
  114. else
  115. {
  116. frag_color = mix(result, u_outline_color, abs(sum.a));
  117. }
  118. frag_color.a = frag_color.a > 0.5 ? 1.0 : 0.0;
  119. }
  120. [defaults]
  121. u_layer0 = 0
  122. u_layer1 = 1
  123. u_layer2 = 2
  124. u_background_color = [0.965, 0.965, 0.965, 1.0]
  125. u_outline_strength = 1.0
  126. u_outline_color = [0.05, 0.66, 0.89, 1.0]
  127. u_error_color = [1.0, 0.0, 0.0, 1.0]
  128. [bindings]
  129. [attributes]
  130. a_vertex = vertex
  131. a_uvs = uv