2016-09-11 18:42:30 +02:00
|
|
|
#version 450
|
|
|
|
|
|
|
|
|
|
#extension GL_ARB_sparse_texture2 : enable
|
2016-09-17 19:08:27 +02:00
|
|
|
#extension GL_ARB_sparse_texture_clamp : enable
|
2016-09-11 18:42:30 +02:00
|
|
|
|
|
|
|
|
layout (binding = 1) uniform sampler2D samplerColor;
|
|
|
|
|
|
|
|
|
|
layout (location = 0) in vec2 inUV;
|
|
|
|
|
layout (location = 1) in float inLodBias;
|
2016-10-01 13:54:50 +02:00
|
|
|
layout (location = 2) in vec3 inNormal;
|
|
|
|
|
layout (location = 3) in vec3 inViewVec;
|
|
|
|
|
layout (location = 4) in vec3 inLightVec;
|
2016-09-11 18:42:30 +02:00
|
|
|
|
|
|
|
|
layout (location = 0) out vec4 outFragColor;
|
|
|
|
|
|
|
|
|
|
void main()
|
|
|
|
|
{
|
2016-09-17 19:08:27 +02:00
|
|
|
vec4 color = vec4(0.0);
|
|
|
|
|
|
2016-09-11 18:42:30 +02:00
|
|
|
// Get residency code for current texel
|
2016-09-17 19:08:27 +02:00
|
|
|
int residencyCode = sparseTextureARB(samplerColor, inUV, color, inLodBias);
|
|
|
|
|
|
|
|
|
|
// Fetch sparse until we get a valid texel
|
|
|
|
|
float minLod = 1.0;
|
|
|
|
|
while (!sparseTexelsResidentARB(residencyCode))
|
|
|
|
|
{
|
|
|
|
|
residencyCode = sparseTextureClampARB(samplerColor, inUV, minLod, color);
|
|
|
|
|
minLod += 1.0f;
|
|
|
|
|
}
|
2016-10-01 13:54:50 +02:00
|
|
|
|
2016-09-11 18:42:30 +02:00
|
|
|
// Check if texel is resident
|
|
|
|
|
bool texelResident = sparseTexelsResidentARB(residencyCode);
|
|
|
|
|
|
2016-10-01 13:54:50 +02:00
|
|
|
if (!texelResident)
|
2016-09-11 18:42:30 +02:00
|
|
|
{
|
|
|
|
|
color = vec4(1.0, 0.0, 0.0, 0.0);
|
|
|
|
|
}
|
|
|
|
|
|
2016-10-01 13:54:50 +02:00
|
|
|
vec3 N = normalize(inNormal);
|
2016-10-20 21:30:37 +02:00
|
|
|
|
|
|
|
|
N = normalize((inNormal - 0.5) * 2.0);
|
|
|
|
|
|
2016-10-01 13:54:50 +02:00
|
|
|
vec3 L = normalize(inLightVec);
|
|
|
|
|
vec3 R = reflect(-L, N);
|
|
|
|
|
vec3 diffuse = max(dot(N, L), 0.25) * color.rgb;
|
|
|
|
|
outFragColor = vec4(diffuse, 1.0);
|
2016-09-11 18:42:30 +02:00
|
|
|
}
|