blit.glsl 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #[vertex]
  2. #version 450
  3. #VERSION_DEFINES
  4. layout(push_constant, std140) uniform Pos {
  5. vec4 src_rect;
  6. vec4 dst_rect;
  7. vec2 eye_center;
  8. float k1;
  9. float k2;
  10. float upscale;
  11. float aspect_ratio;
  12. uint layer;
  13. uint pad1;
  14. }
  15. data;
  16. layout(location = 0) out vec2 uv;
  17. void main() {
  18. vec2 base_arr[4] = vec2[](vec2(0.0, 0.0), vec2(0.0, 1.0), vec2(1.0, 1.0), vec2(1.0, 0.0));
  19. uv = data.src_rect.xy + base_arr[gl_VertexIndex] * data.src_rect.zw;
  20. vec2 vtx = data.dst_rect.xy + base_arr[gl_VertexIndex] * data.dst_rect.zw;
  21. gl_Position = vec4(vtx * 2.0 - 1.0, 0.0, 1.0);
  22. }
  23. #[fragment]
  24. #version 450
  25. #VERSION_DEFINES
  26. layout(push_constant, std140) uniform Pos {
  27. vec4 src_rect;
  28. vec4 dst_rect;
  29. vec2 eye_center;
  30. float k1;
  31. float k2;
  32. float upscale;
  33. float aspect_ratio;
  34. uint layer;
  35. uint pad1;
  36. }
  37. data;
  38. layout(location = 0) in vec2 uv;
  39. layout(location = 0) out vec4 color;
  40. #ifdef USE_LAYER
  41. layout(binding = 0) uniform sampler2DArray src_rt;
  42. #else
  43. layout(binding = 0) uniform sampler2D src_rt;
  44. #endif
  45. void main() {
  46. #ifdef APPLY_LENS_DISTORTION
  47. vec2 coords = uv * 2.0 - 1.0;
  48. vec2 offset = coords - data.eye_center;
  49. // take aspect ratio into account
  50. offset.y /= data.aspect_ratio;
  51. // distort
  52. vec2 offset_sq = offset * offset;
  53. float radius_sq = offset_sq.x + offset_sq.y;
  54. float radius_s4 = radius_sq * radius_sq;
  55. float distortion_scale = 1.0 + (data.k1 * radius_sq) + (data.k2 * radius_s4);
  56. offset *= distortion_scale;
  57. // reapply aspect ratio
  58. offset.y *= data.aspect_ratio;
  59. // add our eye center back in
  60. coords = offset + data.eye_center;
  61. coords /= data.upscale;
  62. // and check our color
  63. if (coords.x < -1.0 || coords.y < -1.0 || coords.x > 1.0 || coords.y > 1.0) {
  64. color = vec4(0.0, 0.0, 0.0, 1.0);
  65. } else {
  66. // layer is always used here
  67. coords = (coords + vec2(1.0)) / vec2(2.0);
  68. color = texture(src_rt, vec3(coords, data.layer));
  69. }
  70. #elif defined(USE_LAYER)
  71. color = texture(src_rt, vec3(uv, data.layer));
  72. #else
  73. color = texture(src_rt, uv);
  74. #endif
  75. }