2015-04-16 16:55:32 +00:00
|
|
|
#version 330 core
|
|
|
|
//precision highp float;
|
|
|
|
|
|
|
|
in Fragment
|
|
|
|
{
|
|
|
|
vec4 color;
|
|
|
|
} fragment;
|
|
|
|
|
|
|
|
in Vert
|
|
|
|
{
|
|
|
|
vec2 texcoord;
|
|
|
|
} vert;
|
|
|
|
|
|
|
|
uniform sampler2D Diffuse;
|
|
|
|
uniform sampler2DShadow shadowMap;
|
2017-06-01 03:32:45 +00:00
|
|
|
uniform mat4 ViewMatrixInverse;
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2017-06-01 03:32:45 +00:00
|
|
|
in vec3 lightPos,cameraPosition, normal,ambient;
|
2015-04-16 16:55:32 +00:00
|
|
|
in vec4 ShadowCoord;
|
2017-06-01 03:32:45 +00:00
|
|
|
in vec4 vertexPos;
|
|
|
|
in float materialShininess;
|
|
|
|
in vec3 lightSpecularIntensity;
|
|
|
|
in vec3 materialSpecularColor;
|
2015-04-16 16:55:32 +00:00
|
|
|
|
|
|
|
out vec4 color;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void main(void)
|
|
|
|
{
|
2017-05-13 14:38:00 +00:00
|
|
|
vec4 texel = fragment.color*texture(Diffuse,vert.texcoord);
|
2015-04-16 16:55:32 +00:00
|
|
|
vec3 ct,cf;
|
|
|
|
float intensity,at,af;
|
2017-05-13 14:38:00 +00:00
|
|
|
if (fragment.color.w==0)
|
|
|
|
discard;
|
2017-06-01 03:32:45 +00:00
|
|
|
vec3 lightDir = normalize(lightPos);
|
|
|
|
|
|
|
|
vec3 normalDir = normalize(normal);
|
|
|
|
|
|
|
|
intensity = 0.5+0.5*clamp( dot( normalDir,lightDir ), -1,1 );
|
2015-08-06 02:03:27 +00:00
|
|
|
|
2015-04-16 16:55:32 +00:00
|
|
|
af = 1.0;
|
|
|
|
|
|
|
|
ct = texel.rgb;
|
|
|
|
at = texel.a;
|
|
|
|
|
|
|
|
//float bias = 0.005f;
|
|
|
|
|
2017-06-01 03:32:45 +00:00
|
|
|
vec3 specularReflection;
|
2016-10-14 22:06:09 +00:00
|
|
|
|
2017-06-01 03:32:45 +00:00
|
|
|
if (dot(normalDir, lightDir) < 0.0)
|
|
|
|
{
|
|
|
|
specularReflection = vec3(0.0, 0.0, 0.0);
|
|
|
|
}
|
|
|
|
else // light source on the right side
|
|
|
|
{
|
|
|
|
vec3 surfaceToLight = normalize(lightPos - vertexPos.xyz);
|
|
|
|
vec3 surfaceToCamera = normalize(cameraPosition - vertexPos.xyz);
|
|
|
|
|
|
|
|
|
|
|
|
float specularCoefficient = 0.0;
|
|
|
|
specularCoefficient = pow(max(0.0, dot(surfaceToCamera, reflect(-surfaceToLight, normalDir))), materialShininess);
|
|
|
|
specularReflection = specularCoefficient * materialSpecularColor * lightSpecularIntensity;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2016-10-14 22:06:09 +00:00
|
|
|
float visibility = texture(shadowMap, vec3(ShadowCoord.xy,(ShadowCoord.z)/ShadowCoord.w));
|
2017-04-23 14:35:13 +00:00
|
|
|
if (intensity<0.5)
|
|
|
|
visibility = 0;
|
|
|
|
|
2015-08-06 02:03:27 +00:00
|
|
|
intensity = 0.7*intensity + 0.3*intensity*visibility;
|
2015-04-16 16:55:32 +00:00
|
|
|
|
2017-06-01 03:32:45 +00:00
|
|
|
cf = intensity*(vec3(1.0,1.0,1.0)-ambient)+ambient+specularReflection*visibility;
|
2015-08-06 02:03:27 +00:00
|
|
|
color = vec4(ct * cf, fragment.color.w);
|
2015-04-16 16:55:32 +00:00
|
|
|
}
|