diff --git a/examples/shaders/resources/shaders/glsl100/deferred_shading.fs b/examples/shaders/resources/shaders/glsl100/deferred_shading.fs index d782792b9..5a6b2bd33 100644 --- a/examples/shaders/resources/shaders/glsl100/deferred_shading.fs +++ b/examples/shaders/resources/shaders/glsl100/deferred_shading.fs @@ -1,12 +1,11 @@ -#version 100 +#version 300 es + +precision highp float; -precision mediump float; +out vec4 finalColor; -// Input vertex attributes (from vertex shader) -varying vec2 fragTexCoord; -varying vec4 fragColor; +in vec2 texCoord; -// Input uniform values uniform sampler2D gPosition; uniform sampler2D gNormal; uniform sampler2D gAlbedoSpec; @@ -26,34 +25,32 @@ uniform vec3 viewPosition; const float QUADRATIC = 0.032; const float LINEAR = 0.09; -void main() -{ - vec3 fragPosition = texture2D(gPosition, fragTexCoord).rgb; - vec3 normal = texture2D(gNormal, fragTexCoord).rgb; - vec3 albedo = texture2D(gAlbedoSpec, fragTexCoord).rgb; - float specular = texture2D(gAlbedoSpec, fragTexCoord).a; +void main() { + vec3 fragPosition = texture(gPosition, texCoord).rgb; + vec3 normal = texture(gNormal, texCoord).rgb; + vec3 albedo = texture(gAlbedoSpec, texCoord).rgb; + float specular = texture(gAlbedoSpec, texCoord).a; - vec3 ambient = albedo*vec3(0.1); + vec3 ambient = albedo * vec3(0.1f); vec3 viewDirection = normalize(viewPosition - fragPosition); - for (int i = 0; i < NR_LIGHTS; ++i) + for(int i = 0; i < NR_LIGHTS; ++i) { if(lights[i].enabled == 0) continue; vec3 lightDirection = lights[i].position - fragPosition; - vec3 diffuse = max(dot(normal, lightDirection), 0.0)*albedo*lights[i].color.xyz; + vec3 diffuse = max(dot(normal, lightDirection), 0.0) * albedo * lights[i].color.xyz; vec3 halfwayDirection = normalize(lightDirection + viewDirection); float spec = pow(max(dot(normal, halfwayDirection), 0.0), 32.0); - vec3 specular = specular*spec*lights[i].color.xyz; + vec3 specular = specular * spec * lights[i].color.xyz; // Attenuation float distance = length(lights[i].position - fragPosition); - float attenuation = 1.0/(1.0 + LINEAR * distance + QUADRATIC*distance*distance); + float attenuation = 1.0 / (1.0 + LINEAR * distance + QUADRATIC * distance * distance); diffuse *= attenuation; specular *= attenuation; ambient += diffuse + specular; } - gl_FragColor = vec4(ambient, 1.0); + finalColor = vec4(ambient, 1.0); } -