#version 430 core uniform vec3 lightPos; uniform vec3 lightColor; uniform vec3 cameraPos; uniform bool atmosphereCheck; in vec3 vecNormal; in vec3 worldPos; in vec2 vtc; out vec4 outColor; uniform sampler2D colorTexture; vec3 toneMapping(vec3 color) { float exposure = 0.06; vec3 mapped = 1 - exp(-color * exposure); return mapped; } void main() { vec3 normal = normalize(vecNormal); vec3 viewDir = normalize(cameraPos - worldPos); vec3 textureColor = texture2D(colorTexture, vtc).rgb; if (atmosphereCheck) { float atmosphereDot = dot(normal, viewDir); vec3 atmosphereColor = vec3(1.0, 0.08, 0.02); textureColor = mix(textureColor, atmosphereColor, pow(1 - atmosphereDot, 3)); } vec3 distance = lightColor / pow(length(lightPos - worldPos), 2.0) * 25; vec3 toneMappedColor = toneMapping(textureColor * distance); //gamma correction toneMappedColor = pow(toneMappedColor, vec3(1.0/2.2)); outColor = vec4(toneMappedColor * lightColor * 0.2f, 1.0); }