1
0
mirror of https://github.com/moparisthebest/minetest synced 2024-11-17 06:45:18 -05:00
minetest/client/shaders/leaves_shader/opengl_fragment.glsl

55 lines
1.5 KiB
Plaintext
Raw Normal View History

2013-12-03 11:21:40 -05:00
uniform sampler2D baseTexture;
uniform sampler2D normalTexture;
uniform sampler2D useNormalmap;
uniform vec4 skyBgColor;
uniform float fogDistance;
uniform vec3 eyePosition;
varying vec3 vPosition;
varying vec3 eyeVec;
const float e = 2.718281828459;
void main (void)
{
vec3 color;
vec2 uv = gl_TexCoord[0].st;
#ifdef USE_NORMALMAPS
2013-12-08 02:01:20 -05:00
float use_normalmap = texture2D(useNormalmap,vec2(1.0,1.0)).r;
#endif
2013-12-08 02:01:20 -05:00
#ifdef ENABLE_BUMPMAPPING
if (use_normalmap > 0.0) {
2013-12-03 11:21:40 -05:00
vec3 base = texture2D(baseTexture, uv).rgb;
vec3 vVec = normalize(eyeVec);
vec3 bump = normalize(texture2D(normalTexture, uv).xyz * 2.0 - 1.0);
vec3 R = reflect(-vVec, bump);
vec3 lVec = normalize(vVec);
float diffuse = max(dot(lVec, bump), 0.0);
float specular = pow(clamp(dot(R, lVec), 0.0, 1.0),1.0);
color = mix (base,diffuse*base,1.0) + 0.1 * specular * diffuse;
} else {
color = texture2D(baseTexture, uv).rgb;
}
2013-12-08 02:01:20 -05:00
#else
color = texture2D(baseTexture, uv).rgb;
#endif
2013-12-03 11:21:40 -05:00
float alpha = texture2D(baseTexture, uv).a;
vec4 col = vec4(color.r, color.g, color.b, alpha);
col *= gl_Color;
col = col * col; // SRGB -> Linear
col *= 1.8;
col.r = 1.0 - exp(1.0 - col.r) / e;
col.g = 1.0 - exp(1.0 - col.g) / e;
col.b = 1.0 - exp(1.0 - col.b) / e;
col = sqrt(col); // Linear -> SRGB
if(fogDistance != 0.0){
float d = max(0.0, min(vPosition.z / fogDistance * 1.5 - 0.6, 1.0));
col = mix(col, skyBgColor, d);
}
gl_FragColor = vec4(col.r, col.g, col.b, alpha);
2013-12-03 11:21:40 -05:00
}