1
0

60 lines
1.3 KiB
Plaintext
Raw Normal View History

2020-02-16 22:37:28 +03:00
uniform mat4 mWorld;
uniform vec3 eyePosition;
2022-02-11 15:29:12 +03:00
uniform mediump float fogDistance;
2020-02-16 22:37:28 +03:00
uniform float animationTimer;
varying vec3 vNormal;
varying vec3 vPosition;
varying vec3 worldPosition;
varying lowp vec4 varColor;
#ifdef GL_ES
varying mediump vec2 varTexCoord;
#else
centroid varying vec2 varTexCoord;
#endif
2020-02-16 22:37:28 +03:00
2022-02-11 15:29:12 +03:00
varying mediump vec3 eyeVec;
2020-02-16 22:37:28 +03:00
varying float vIDiff;
const float e = 2.718281828459;
const float BS = 10.0;
float directional_ambient(vec3 normal)
{
vec3 v = normal * normal;
if (normal.y < 0.0)
return dot(v, vec3(0.670820, 0.447213, 0.836660));
2020-02-16 22:37:28 +03:00
return dot(v, vec3(0.670820, 1.000000, 0.836660));
2020-02-16 22:37:28 +03:00
}
void main(void)
{
varTexCoord = (mTexture * inTexCoord0).st;
gl_Position = mWorldViewProj * inVertexPosition;
2020-02-16 22:37:28 +03:00
vPosition = gl_Position.xyz;
vNormal = inVertexNormal;
worldPosition = (mWorld * inVertexPosition).xyz;
2022-02-11 15:29:12 +03:00
eyeVec = -(mWorldView * inVertexPosition).xyz / fogDistance;
2020-06-16 22:48:31 +03:00
#if (MATERIAL_TYPE == TILE_MATERIAL_PLAIN) || (MATERIAL_TYPE == TILE_MATERIAL_PLAIN_ALPHA)
vIDiff = 1.0;
#else
// This is intentional comparison with zero without any margin.
// If normal is not equal to zero exactly, then we assume it's a valid, just not normalized vector
vIDiff = length(inVertexNormal) == 0.0
? 1.0
: directional_ambient(normalize(inVertexNormal));
2020-06-16 22:48:31 +03:00
#endif
2020-02-16 22:37:28 +03:00
2022-05-23 10:31:22 +03:00
#ifdef GL_ES
varColor = inVertexColor.bgra;
#else
varColor = inVertexColor;
2022-05-23 10:31:22 +03:00
#endif
2020-02-16 22:37:28 +03:00
}