1
0
mirror of synced 2025-01-22 11:23:42 +01:00

97 lines
2.2 KiB
GLSL
Raw Normal View History

#version 330
in vec3 normal;
in vec3 position;
2019-05-11 18:17:35 -04:00
in vec2 f_texcoord0;
in vec2 f_texcoord1;
in vec2 f_texcoord2;
in vec2 f_texcoord3;
2019-05-11 21:25:29 -04:00
in vec4 vertexColor;
in vec3 tangent;
2019-05-11 18:17:35 -04:00
in vec3 boneWeightsColored;
uniform vec3 difLightDirection;
uniform vec3 difLightColor;
uniform vec3 ambLightColor;
uniform int colorOverride;
uniform int renderType;
uniform int renderVertColor;
uniform mat4 modelview;
2019-05-11 18:17:35 -04:00
uniform int HasDiffuse;
uniform sampler2D DiffuseMap;
2019-05-11 21:25:29 -04:00
uniform sampler2D UVTestPattern;
2019-05-11 18:17:35 -04:00
out vec4 FragColor;
void main()
{
if (colorOverride == 1)
{
// Wireframe color.
if (renderVertColor == 1)
{
2019-05-11 21:25:29 -04:00
FragColor = vertexColor;
}
else
{
FragColor = vec4(1);
}
return;
}
2019-05-11 21:25:29 -04:00
vec3 N = normal;
2019-05-11 16:23:29 -04:00
// Diffuse lighting.
float halfLambert = dot(difLightDirection, normal) * 0.5 + 0.5;
2019-05-11 18:17:35 -04:00
vec4 diffuseMapColor = vec4(texture(DiffuseMap, f_texcoord0).rgb, 1);
2019-05-11 16:23:29 -04:00
diffuseMapColor *= halfLambert;
FragColor = vec4(0);
FragColor.rgb += diffuseMapColor.rgb;
if (renderVertColor == 1)
2019-05-11 21:25:29 -04:00
FragColor *= min(vertexColor, vec4(1));
2019-05-11 16:11:27 -04:00
FragColor.rgb *= min(boneWeightsColored, vec3(1));
2019-05-11 21:25:29 -04:00
vec2 displayTexCoord = f_texcoord0;
vec3 displayNormal = (normal.xyz * 0.5) + 0.5;
2019-05-11 16:11:27 -04:00
if (renderType == 1) // normals color
FragColor = vec4(displayNormal.rgb,1);
2019-05-11 21:25:29 -04:00
else if (renderType == 2) // Lighting
{
float halfLambert = dot(difLightDirection, N) * 0.5 + 0.5;
FragColor = vec4(vec3(halfLambert), 1);
}
else if (renderType == 3) //DiffuseColor
FragColor = vec4(texture(DiffuseMap, displayTexCoord).rgb, 1);
else if (renderType == 5) // vertexColor
FragColor = vertexColor;
else if (renderType == 7) // uv coords
FragColor = vec4(displayTexCoord.x, displayTexCoord.y, 1, 1);
else if (renderType == 8) // uv test pattern
{
FragColor = vec4(texture(UVTestPattern, displayTexCoord).rgb, 1);
}
else if (renderType == 9) //Display tangents
{
vec3 displayTangent = (tangent * 0.5) + 0.5;
if (dot(tangent, vec3(1)) == 0)
displayTangent = vec3(0);
2019-05-11 21:25:29 -04:00
FragColor = vec4(displayTangent,1);
}
else if (renderType == 12)
{
FragColor.rgb = boneWeightsColored;
}
}