geometry.gs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. #version 430
  2. layout (points) in;
  3. layout (triangle_strip, max_vertices = 12) out;
  4. uniform mat4 proj;
  5. uniform mat4 view;
  6. uniform vec3 lightPos;
  7. uniform vec3 viewPos;
  8. in vec3 varTexture[];
  9. in int varIndex[];
  10. out vec3 varPositionG;
  11. out vec2 varTextureG;
  12. out vec3 tangentLightPosG;
  13. out vec3 tangentViewPosG;
  14. out vec3 tangentFragPosG;
  15. vec3 vectors[13] = {
  16. vec3(0.0, 0.0, 0.0), vec3(0.5, 1.0, 1.0), vec3(0.0, 0.5, 1.0),
  17. vec3(0.0, 1.0, 0.5), vec3(1.0, 0.5, 1.0), vec3(1.0, 1.0, 0.5),
  18. vec3(0.5, 1.0, 0.0), vec3(1.0, 0.5, 0.0), vec3(0.0, 0.5, 0.0),
  19. vec3(0.0, 0.0, 0.5), vec3(0.5, 0.0, 1.0), vec3(1.0, 0.0, 0.5),
  20. vec3(0.5, 0.0, 0.0)};
  21. int table[3072] = {
  22. 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  23. 4, 1, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 5, 2, 2, 5, 4, 0, 0, 0, 0, 0, 0,
  24. 5, 6, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 5, 6, 7, 3, 1, 2, 0, 0, 0, 0, 0, 0,
  25. 7, 4, 6, 6, 4, 1, 0, 0, 0, 0, 0, 0, 3, 6, 2, 6, 7, 2, 2, 7, 4, 0, 0, 0,
  26. 3, 8, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0, 6, 1, 8, 8, 1, 2, 0, 0, 0, 0, 0, 0,
  27. 6, 3, 8, 1, 5, 4, 0, 0, 0, 0, 0, 0, 6, 5, 8, 5, 4, 8, 8, 4, 2, 0, 0, 0,
  28. 5, 3, 7, 7, 3, 8, 0, 0, 0, 0, 0, 0, 5, 1, 7, 1, 2, 7, 7, 2, 8, 0, 0, 0,
  29. 1, 3, 4, 3, 8, 4, 4, 8, 7, 0, 0, 0, 8, 7, 2, 7, 4, 2, 0, 0, 0, 0, 0, 0,
  30. 9, 2, 10, 0, 0, 0, 0, 0, 0, 0, 0, 0, 9, 3, 10, 10, 3, 1, 0, 0, 0, 0, 0, 0,
  31. 4, 1, 5, 2, 10, 9, 0, 0, 0, 0, 0, 0, 4, 10, 5, 10, 9, 5, 5, 9, 3, 0, 0, 0,
  32. 9, 2, 10, 7, 5, 6, 0, 0, 0, 0, 0, 0, 9, 3, 10, 10, 3, 1, 6, 7, 5, 0, 0, 0,
  33. 7, 4, 6, 6, 4, 1, 10, 9, 2, 0, 0, 0, 4, 10, 7, 10, 3, 7, 3, 10, 9, 3, 6, 7,
  34. 9, 2, 10, 3, 8, 6, 0, 0, 0, 0, 0, 0, 9, 8, 10, 8, 6, 10, 10, 6, 1, 0, 0, 0,
  35. 8, 6, 3, 2, 10, 9, 4, 1, 5, 0, 0, 0, 5, 4, 6, 4, 10, 6, 10, 8, 6, 8, 10, 9,
  36. 5, 3, 7, 7, 3, 8, 2, 10, 9, 0, 0, 0, 9, 7, 1, 10, 9, 1, 7, 5, 1, 7, 9, 8,
  37. 10, 9, 8, 4, 10, 8, 4, 10, 7, 3, 2, 1, 10, 9, 8, 4, 10, 8, 4, 8, 7, 0, 0, 0,
  38. 10, 4, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10, 4, 11, 1, 2, 3, 0, 0, 0, 0, 0, 0,
  39. 5, 11, 1, 1, 11, 10, 0, 0, 0, 0, 0, 0, 10, 2, 11, 2, 3, 11, 11, 3, 5, 0, 0, 0,
  40. 7, 5, 6, 4, 11, 10, 0, 0, 0, 0, 0, 0, 2, 3, 1, 4, 11, 10, 7, 5, 6, 0, 0, 0,
  41. 7, 11, 6, 11, 10, 6, 6, 10, 1, 0, 0, 0, 6, 7, 3, 7, 11, 3, 11, 2, 3, 2, 11, 10,
  42. 10, 4, 11, 8, 6, 3, 0, 0, 0, 0, 0, 0, 6, 1, 8, 8, 1, 2, 4, 11, 10, 0, 0, 0,
  43. 10, 1, 11, 11, 1, 5, 3, 8, 6, 0, 0, 0, 10, 8, 5, 11, 10, 5, 8, 6, 5, 8, 10, 2,
  44. 8, 7, 3, 3, 7, 5, 11, 10, 4, 0, 0, 0, 11, 10, 2, 7, 11, 2, 7, 11, 8, 1, 4, 5,
  45. 7, 11, 8, 11, 1, 8, 1, 11, 10, 1, 3, 8, 11, 10, 2, 7, 11, 2, 7, 2, 8, 0, 0, 0,
  46. 11, 9, 4, 4, 9, 2, 0, 0, 0, 0, 0, 0, 1, 4, 3, 4, 11, 3, 3, 11, 9, 0, 0, 0,
  47. 2, 1, 9, 1, 5, 9, 9, 5, 11, 0, 0, 0, 3, 5, 9, 5, 11, 9, 0, 0, 0, 0, 0, 0,
  48. 2, 4, 9, 9, 4, 11, 5, 6, 7, 0, 0, 0, 6, 7, 11, 3, 6, 11, 3, 6, 9, 4, 5, 1,
  49. 1, 7, 9, 7, 11, 9, 2, 1, 9, 7, 1, 6, 6, 7, 11, 3, 6, 11, 3, 11, 9, 0, 0, 0,
  50. 11, 9, 4, 4, 9, 2, 8, 6, 3, 0, 0, 0, 1, 4, 6, 9, 4, 6, 9, 4, 11, 9, 8, 6,
  51. 8, 6, 5, 9, 8, 5, 9, 8, 11, 1, 3, 2, 8, 6, 5, 9, 8, 5, 9, 5, 11, 0, 0, 0,
  52. 7, 11, 9, 7, 9, 9, 4, 5, 2, 5, 2, 2, 11, 9, 8, 11, 8, 7, 1, 4, 5, 0, 0, 0,
  53. 8, 7, 11, 8, 11, 9, 1, 3, 2, 0, 0, 0, 11, 9, 8, 11, 8, 7, 0, 0, 0, 0, 0, 0,
  54. 11, 7, 12, 0, 0, 0, 0, 0, 0, 0, 0, 0, 11, 7, 12, 2, 3, 1, 0, 0, 0, 0, 0, 0,
  55. 11, 7, 12, 5, 4, 1, 0, 0, 0, 0, 0, 0, 3, 5, 2, 2, 5, 4, 7, 12, 11, 0, 0, 0,
  56. 11, 5, 12, 12, 5, 6, 0, 0, 0, 0, 0, 0, 11, 5, 12, 12, 5, 6, 1, 2, 3, 0, 0, 0,
  57. 11, 4, 12, 4, 1, 12, 12, 1, 6, 0, 0, 0, 11, 2, 6, 12, 11, 6, 2, 3, 6, 2, 11, 4,
  58. 7, 12, 11, 8, 6, 3, 0, 0, 0, 0, 0, 0, 2, 8, 1, 1, 8, 6, 12, 11, 7, 0, 0, 0,
  59. 4, 1, 5, 7, 12, 11, 8, 6, 3, 0, 0, 0, 12, 11, 4, 8, 12, 4, 8, 12, 2, 5, 7, 6,
  60. 8, 12, 3, 12, 11, 3, 3, 11, 5, 0, 0, 0, 8, 12, 2, 12, 5, 2, 5, 12, 11, 5, 1, 2,
  61. 3, 8, 1, 8, 12, 1, 12, 4, 1, 4, 12, 11, 12, 11, 4, 8, 12, 4, 8, 4, 2, 0, 0, 0,
  62. 12, 11, 7, 10, 9, 2, 0, 0, 0, 0, 0, 0, 1, 10, 3, 3, 10, 9, 11, 7, 12, 0, 0, 0,
  63. 7, 12, 11, 4, 1, 5, 2, 10, 9, 0, 0, 0, 7, 12, 9, 5, 7, 9, 5, 7, 3, 10, 11, 4,
  64. 6, 12, 5, 5, 12, 11, 9, 2, 10, 0, 0, 0, 12, 9, 3, 12, 3, 3, 10, 11, 1, 11, 1, 1,
  65. 11, 4, 12, 4, 1, 12, 4, 1, 6, 10, 9, 2, 9, 3, 6, 9, 6, 12, 4, 10, 11, 0, 0, 0,
  66. 6, 3, 8, 12, 11, 7, 10, 9, 2, 0, 0, 0, 11, 7, 6, 10, 11, 6, 10, 11, 1, 8, 12, 9,
  67. 8, 12, 9, 7, 6, 5, 2, 1, 3, 7, 6, 5, 9, 8, 12, 5, 7, 6, 11, 4, 10, 0, 0, 0,
  68. 8, 12, 3, 12, 11, 3, 12, 11, 5, 9, 2, 10, 11, 5, 1, 11, 1, 10, 8, 12, 9, 0, 0, 0,
  69. 8, 12, 9, 4, 10, 11, 2, 1, 3, 0, 0, 0, 10, 11, 4, 12, 9, 8, 0, 0, 0, 0, 0, 0,
  70. 12, 10, 7, 7, 10, 4, 0, 0, 0, 0, 0, 0, 12, 10, 7, 7, 10, 4, 2, 3, 1, 0, 0, 0,
  71. 5, 7, 1, 7, 12, 1, 1, 12, 10, 0, 0, 0, 7, 12, 10, 3, 7, 10, 7, 3, 5, 2, 3, 10,
  72. 4, 5, 10, 5, 6, 10, 10, 6, 12, 0, 0, 0, 4, 5, 10, 5, 6, 10, 5, 6, 12, 1, 2, 3,
  73. 6, 12, 10, 1, 6, 10, 0, 0, 0, 0, 0, 0, 2, 3, 6, 10, 2, 6, 10, 6, 12, 0, 0, 0,
  74. 4, 7, 10, 10, 7, 12, 6, 3, 8, 0, 0, 0, 8, 6, 2, 6, 2, 2, 7, 12, 10, 7, 10, 10,
  75. 5, 7, 1, 7, 12, 1, 7, 12, 10, 6, 3, 8, 12, 10, 2, 12, 2, 8, 5, 7, 6, 0, 0, 0,
  76. 4, 12, 3, 4, 5, 3, 8, 12, 3, 4, 12, 10, 2, 8, 12, 2, 12, 10, 5, 1, 4, 0, 0, 0,
  77. 3, 8, 12, 1, 3, 12, 1, 12, 10, 0, 0, 0, 12, 10, 2, 12, 2, 8, 0, 0, 0, 0, 0, 0,
  78. 12, 9, 7, 9, 2, 7, 7, 2, 4, 0, 0, 0, 4, 12, 3, 12, 9, 3, 1, 4, 3, 12, 4, 7,
  79. 2, 1, 5, 9, 2, 5, 7, 9, 5, 9, 7, 12, 7, 12, 9, 5, 7, 9, 5, 9, 3, 0, 0, 0,
  80. 9, 2, 4, 6, 9, 4, 9, 6, 12, 5, 6, 4, 6, 12, 9, 6, 9, 3, 4, 5, 1, 0, 0, 0,
  81. 9, 2, 1, 12, 9, 1, 12, 1, 6, 0, 0, 0, 9, 3, 6, 9, 6, 12, 0, 0, 0, 0, 0, 0,
  82. 12, 9, 7, 9, 2, 7, 9, 2, 4, 8, 6, 3, 6, 1, 4, 6, 4, 7, 9, 8, 12, 0, 0, 0,
  83. 5, 7, 6, 9, 8, 12, 3, 2, 1, 0, 0, 0, 8, 12, 9, 7, 6, 5, 0, 0, 0, 0, 0, 0,
  84. 2, 4, 5, 2, 5, 3, 12, 9, 8, 0, 0, 0, 8, 12, 9, 1, 4, 5, 0, 0, 0, 0, 0, 0,
  85. 9, 8, 12, 3, 2, 1, 0, 0, 0, 0, 0, 0, 8, 12, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  86. 12, 8, 9, 0, 0, 0, 0, 0, 0, 0, 0, 0, 8, 9, 12, 2, 3, 1, 0, 0, 0, 0, 0, 0,
  87. 12, 8, 9, 4, 1, 5, 0, 0, 0, 0, 0, 0, 4, 2, 5, 5, 2, 3, 9, 12, 8, 0, 0, 0,
  88. 12, 8, 9, 6, 7, 5, 0, 0, 0, 0, 0, 0, 7, 5, 6, 8, 9, 12, 2, 3, 1, 0, 0, 0,
  89. 1, 6, 4, 4, 6, 7, 8, 9, 12, 0, 0, 0, 9, 12, 7, 2, 9, 7, 2, 9, 4, 6, 8, 3,
  90. 3, 9, 6, 6, 9, 12, 0, 0, 0, 0, 0, 0, 2, 9, 1, 9, 12, 1, 1, 12, 6, 0, 0, 0,
  91. 12, 6, 9, 9, 6, 3, 5, 4, 1, 0, 0, 0, 2, 9, 4, 9, 6, 4, 6, 9, 12, 6, 5, 4,
  92. 12, 7, 9, 7, 5, 9, 9, 5, 3, 0, 0, 0, 1, 2, 5, 2, 9, 5, 9, 7, 5, 7, 9, 12,
  93. 12, 4, 3, 9, 12, 3, 4, 1, 3, 4, 12, 7, 9, 12, 7, 2, 9, 7, 2, 7, 4, 0, 0, 0,
  94. 10, 12, 2, 2, 12, 8, 0, 0, 0, 0, 0, 0, 8, 3, 12, 3, 1, 12, 12, 1, 10, 0, 0, 0,
  95. 8, 2, 12, 12, 2, 10, 1, 5, 4, 0, 0, 0, 12, 4, 3, 5, 4, 3, 12, 8, 3, 12, 4, 10,
  96. 10, 12, 2, 2, 12, 8, 7, 5, 6, 0, 0, 0, 7, 5, 1, 12, 7, 1, 12, 7, 10, 3, 6, 8,
  97. 6, 8, 2, 6, 2, 2, 12, 7, 10, 7, 10, 10, 7, 4, 10, 7, 10, 12, 3, 6, 8, 0, 0, 0,
  98. 3, 2, 6, 2, 10, 6, 6, 10, 12, 0, 0, 0, 12, 6, 10, 6, 1, 10, 0, 0, 0, 0, 0, 0,
  99. 5, 4, 10, 6, 5, 10, 6, 5, 12, 2, 1, 3, 5, 4, 10, 6, 5, 10, 6, 10, 12, 0, 0, 0,
  100. 12, 7, 10, 7, 3, 10, 3, 7, 5, 3, 2, 10, 7, 5, 1, 12, 7, 1, 12, 1, 10, 0, 0, 0,
  101. 10, 12, 7, 10, 7, 4, 3, 2, 1, 0, 0, 0, 10, 12, 7, 10, 7, 4, 0, 0, 0, 0, 0, 0,
  102. 11, 10, 4, 9, 12, 8, 0, 0, 0, 0, 0, 0, 12, 8, 9, 10, 4, 11, 1, 2, 3, 0, 0, 0,
  103. 5, 11, 1, 1, 11, 10, 12, 8, 9, 0, 0, 0, 12, 8, 3, 11, 12, 3, 11, 12, 5, 2, 9, 10,
  104. 8, 9, 12, 7, 5, 6, 4, 11, 10, 0, 0, 0, 12, 8, 9, 6, 7, 5, 1, 2, 3, 6, 7, 5,
  105. 7, 11, 6, 11, 10, 6, 11, 10, 1, 12, 8, 9, 3, 6, 8, 11, 12, 7, 9, 10, 2, 0, 0, 0,
  106. 3, 9, 6, 6, 9, 12, 10, 4, 11, 0, 0, 0, 4, 11, 12, 1, 4, 12, 1, 4, 6, 9, 10, 2,
  107. 9, 12, 3, 12, 3, 3, 11, 10, 1, 11, 1, 1, 12, 6, 5, 12, 5, 11, 2, 9, 10, 0, 0, 0,
  108. 12, 7, 9, 7, 5, 9, 7, 5, 3, 11, 10, 4, 12, 7, 11, 1, 4, 5, 10, 2, 9, 0, 0, 0,
  109. 10, 1, 3, 10, 3, 9, 7, 11, 12, 0, 0, 0, 11, 12, 7, 9, 10, 2, 0, 0, 0, 0, 0, 0,
  110. 11, 12, 4, 12, 8, 4, 4, 8, 2, 0, 0, 0, 8, 3, 1, 12, 8, 1, 4, 12, 1, 12, 4, 11,
  111. 12, 8, 2, 5, 12, 2, 12, 5, 11, 1, 5, 2, 12, 8, 3, 11, 12, 3, 11, 3, 5, 0, 0, 0,
  112. 11, 12, 4, 12, 8, 4, 12, 8, 2, 7, 5, 6, 1, 4, 5, 12, 7, 11, 6, 8, 3, 0, 0, 0,
  113. 8, 2, 1, 8, 1, 6, 11, 12, 7, 0, 0, 0, 12, 7, 11, 6, 8, 3, 0, 0, 0, 0, 0, 0,
  114. 2, 11, 6, 11, 12, 6, 3, 2, 6, 11, 2, 4, 4, 11, 12, 1, 4, 12, 1, 12, 6, 0, 0, 0,
  115. 5, 11, 12, 5, 12, 6, 2, 1, 3, 0, 0, 0, 5, 11, 12, 5, 12, 6, 0, 0, 0, 0, 0, 0,
  116. 5, 3, 2, 5, 2, 4, 12, 7, 11, 0, 0, 0, 7, 11, 12, 4, 5, 1, 0, 0, 0, 0, 0, 0,
  117. 7, 11, 12, 3, 2, 1, 0, 0, 0, 0, 0, 0, 7, 11, 12, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  118. 9, 11, 8, 8, 11, 7, 0, 0, 0, 0, 0, 0, 7, 8, 11, 11, 8, 9, 3, 1, 2, 0, 0, 0,
  119. 9, 11, 8, 8, 11, 7, 4, 1, 5, 0, 0, 0, 11, 7, 9, 7, 9, 9, 5, 4, 2, 5, 2, 2,
  120. 6, 8, 5, 8, 9, 5, 5, 9, 11, 0, 0, 0, 6, 8, 5, 8, 9, 5, 8, 9, 11, 3, 1, 2,
  121. 4, 1, 6, 4, 9, 6, 4, 9, 11, 8, 9, 6, 9, 11, 4, 9, 4, 2, 6, 8, 3, 0, 0, 0,
  122. 7, 6, 11, 6, 3, 11, 11, 3, 9, 0, 0, 0, 7, 1, 9, 11, 7, 9, 1, 2, 9, 1, 7, 6,
  123. 7, 6, 11, 6, 3, 11, 6, 3, 9, 5, 4, 1, 4, 2, 9, 4, 9, 11, 6, 5, 7, 0, 0, 0,
  124. 5, 3, 9, 11, 5, 9, 0, 0, 0, 0, 0, 0, 1, 2, 9, 5, 1, 9, 5, 9, 11, 0, 0, 0,
  125. 4, 1, 3, 11, 4, 3, 11, 3, 9, 0, 0, 0, 9, 11, 4, 9, 4, 2, 0, 0, 0, 0, 0, 0,
  126. 10, 11, 2, 11, 7, 2, 2, 7, 8, 0, 0, 0, 11, 7, 8, 1, 11, 8, 11, 1, 10, 3, 1, 8,
  127. 10, 11, 2, 11, 7, 2, 11, 7, 8, 4, 1, 5, 7, 8, 3, 7, 3, 5, 10, 11, 4, 0, 0, 0,
  128. 8, 10, 5, 10, 11, 5, 6, 8, 5, 10, 8, 2, 1, 10, 11, 1, 11, 5, 8, 3, 6, 0, 0, 0,
  129. 1, 6, 8, 1, 8, 2, 11, 4, 10, 0, 0, 0, 4, 10, 11, 6, 8, 3, 0, 0, 0, 0, 0, 0,
  130. 7, 6, 3, 11, 7, 3, 2, 11, 3, 11, 2, 10, 11, 7, 6, 10, 11, 6, 10, 6, 1, 0, 0, 0,
  131. 3, 2, 1, 11, 4, 10, 5, 7, 6, 0, 0, 0, 5, 7, 6, 11, 4, 10, 0, 0, 0, 0, 0, 0,
  132. 2, 10, 11, 3, 2, 11, 3, 11, 5, 0, 0, 0, 11, 5, 1, 11, 1, 10, 0, 0, 0, 0, 0, 0,
  133. 4, 10, 11, 2, 1, 3, 0, 0, 0, 0, 0, 0, 4, 10, 11, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  134. 9, 10, 8, 10, 4, 8, 8, 4, 7, 0, 0, 0, 9, 10, 8, 10, 4, 8, 10, 4, 7, 2, 3, 1,
  135. 7, 9, 1, 9, 10, 1, 5, 7, 1, 9, 7, 8, 3, 5, 7, 3, 7, 8, 10, 2, 9, 0, 0, 0,
  136. 4, 5, 6, 10, 4, 6, 8, 10, 6, 10, 8, 9, 6, 8, 3, 10, 2, 9, 1, 4, 5, 0, 0, 0,
  137. 8, 9, 10, 6, 8, 10, 6, 10, 1, 0, 0, 0, 2, 9, 10, 8, 3, 6, 0, 0, 0, 0, 0, 0,
  138. 10, 4, 7, 3, 10, 7, 10, 3, 9, 6, 3, 7, 4, 7, 6, 4, 6, 1, 9, 10, 2, 0, 0, 0,
  139. 3, 9, 10, 3, 10, 1, 7, 6, 5, 0, 0, 0, 2, 9, 10, 5, 7, 6, 0, 0, 0, 0, 0, 0,
  140. 10, 4, 5, 9, 10, 5, 9, 5, 3, 0, 0, 0, 1, 4, 5, 10, 2, 9, 0, 0, 0, 0, 0, 0,
  141. 3, 9, 10, 3, 10, 1, 0, 0, 0, 0, 0, 0, 2, 9, 10, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  142. 7, 8, 2, 4, 7, 2, 0, 0, 0, 0, 0, 0, 3, 1, 4, 8, 3, 4, 8, 4, 7, 0, 0, 0,
  143. 1, 5, 7, 2, 1, 7, 2, 7, 8, 0, 0, 0, 3, 5, 7, 3, 7, 8, 0, 0, 0, 0, 0, 0,
  144. 5, 6, 8, 4, 5, 8, 4, 8, 2, 0, 0, 0, 3, 6, 8, 5, 1, 4, 0, 0, 0, 0, 0, 0,
  145. 1, 6, 8, 1, 8, 2, 0, 0, 0, 0, 0, 0, 8, 3, 6, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  146. 6, 3, 2, 7, 6, 2, 7, 2, 4, 0, 0, 0, 4, 7, 6, 4, 6, 1, 0, 0, 0, 0, 0, 0,
  147. 6, 5, 7, 1, 3, 2, 0, 0, 0, 0, 0, 0, 6, 5, 7, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  148. 5, 3, 2, 5, 2, 4, 0, 0, 0, 0, 0, 0, 1, 4, 5, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  149. 2, 1, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
  150. };
  151. const float step = 1.0 / 63.0;
  152. void main(void) {
  153. vec4 base = gl_in[0].gl_Position;
  154. int index = varIndex[0] * 12;
  155. for(int i = 0; i < 12; i += 3) {
  156. vec3 offsetA = vectors[table[index + i + 0]];
  157. vec3 offsetB = vectors[table[index + i + 1]];
  158. vec3 offsetC = vectors[table[index + i + 2]];
  159. // position
  160. vec3 a = base.xyz + offsetA;
  161. vec3 b = base.xyz + offsetB;
  162. vec3 c = base.xyz + offsetC;
  163. // texture coords
  164. vec2 ta = (varTexture[0] + offsetA * step).xy;
  165. vec2 tb = (varTexture[0] + offsetB * step).xy;
  166. vec2 tc = (varTexture[0] + offsetC * step).xy;
  167. // normal, same for all vertices
  168. vec3 ab = b - a;
  169. vec3 ac = c - a;
  170. vec3 normal = normalize(cross(ab, ac));
  171. // tangent, same for all vertices
  172. vec2 abt = tb - ta;
  173. vec2 act = tc - ta;
  174. float f = 1.0f / (abt.x * act.y - act.x * abt.y);
  175. vec3 tangent = normalize(f * (act.y * ab - abt.y * ac));
  176. vec3 biTangent = cross(normal, tangent);
  177. mat3 TBN = transpose(mat3(tangent, biTangent, normal));
  178. vec3 tangentLightPos = TBN * lightPos;
  179. vec3 tangentViewPos = TBN * viewPos;
  180. gl_Position = proj * view * vec4(a, 1.0);
  181. varPositionG = a;
  182. varTextureG = ta;
  183. tangentLightPosG = tangentLightPos;
  184. tangentViewPosG = tangentViewPos;
  185. tangentFragPosG = TBN * a;
  186. EmitVertex();
  187. gl_Position = proj * view * vec4(b, 1.0);
  188. varPositionG = b;
  189. varTextureG = tb;
  190. tangentLightPosG = tangentLightPos;
  191. tangentViewPosG = tangentViewPos;
  192. tangentFragPosG = TBN * b;
  193. EmitVertex();
  194. gl_Position = proj * view * vec4(c, 1.0);
  195. varPositionG = c;
  196. varTextureG = tc;
  197. tangentLightPosG = tangentLightPos;
  198. tangentViewPosG = tangentViewPos;
  199. tangentFragPosG = TBN * c;
  200. EmitVertex();
  201. EndPrimitive();
  202. }
  203. }