monado/src/xrt/compositor/shaders/mesh.frag

57 lines
1.4 KiB
GLSL
Raw Normal View History

2019-10-07 23:12:06 +00:00
// Copyright 2017, James Sarrett.
// Copyright 2017, Bastiaan Olij.
// Copyright 2019, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
// Author: James Sarrett <jsarrett@gmail.com>
// Author: Bastiaan Olij <mux213@gmail.com>
// Author: Lubosz Sarnecki <lubosz.sarnecki@collabora.com>
// Author: Pete Black <pete.black@collabora.com>
#version 450
layout (binding = 0) uniform sampler2D texSampler;
layout (binding = 1, std140) uniform UBO
{
// Distoriton coefficients (PanoTools model) [a,b,c,d]
vec4 HmdWarpParam;
// chromatic distortion post scaling
vec4 aberr;
// Position of lens center in m (usually eye_w/2, eye_h/2)
vec2 LensCenter[2];
// Scale from texture co-ords to m (usually eye_w, eye_h)
vec2 ViewportScale;
// Distortion overall scale in m (usually ~eye_w/2)
float WarpScale;
} ubo;
layout (location = 0) in vec2 in_ruv;
layout (location = 1) in vec2 in_guv;
layout (location = 2) in vec2 in_buv;
layout (location = 0) out vec4 out_color;
2019-10-07 23:12:06 +00:00
void main()
{
float r = texture(texSampler, in_ruv).x;
float g = texture(texSampler, in_guv).y;
float b = texture(texSampler, in_buv).z;
#if 0
if (in_ruv.x < 0.0 || in_ruv.x > 1.0 || in_ruv.y < 0.0 || in_ruv.y > 1.0) {
color = vec3(1.0, 0.0, 1.0);
} else {
float t = floor(in_ruv.x * 16) + floor(in_ruv.y * 16);
bool isEven = mod(t, 2.0) == 0.0;
// color = color * float(isEven);
color = vec3(isEven, isEven, isEven);
}
#endif
out_color = vec4(r, g, b, 1.0);
2019-10-07 23:12:06 +00:00
}