Git Refactoring
This commit is contained in:
parent
c700911190
commit
55fcb82edd
35 changed files with 2338 additions and 2361 deletions
78
res/shaders/light.frag
Normal file
78
res/shaders/light.frag
Normal file
|
@ -0,0 +1,78 @@
|
|||
#version 150
|
||||
//precision highp float;
|
||||
uniform mat4 transform;
|
||||
uniform sampler2D materialTex;
|
||||
uniform float materialShininess;
|
||||
uniform vec3 materialSpecularColor;
|
||||
uniform vec3 cameraPosition;
|
||||
|
||||
#define MAX_LIGHTS 10
|
||||
uniform int numLights;
|
||||
uniform struct Light {
|
||||
vec4 position;
|
||||
vec3 intensities; //a.k.a the color of the light
|
||||
float attenuation;
|
||||
float ambientCoefficient;
|
||||
float coneAngle;
|
||||
vec3 coneDirection;
|
||||
} allLights[MAX_LIGHTS];
|
||||
|
||||
in vec2 fragTexCoord;
|
||||
in vec3 fragNormal;
|
||||
in vec3 fragVert;
|
||||
|
||||
out vec4 finalColor;
|
||||
|
||||
vec3 ApplyLight(Light light, vec3 surfaceColor, vec3 normal, vec3 surfacePos, vec3 surfaceToCamera) {
|
||||
vec3 surfaceToLight;
|
||||
float attenuation = 1.0;
|
||||
if(light.position.w == 0.0) {
|
||||
//directional light
|
||||
surfaceToLight = normalize(light.position.xyz);
|
||||
attenuation = 1.0; //no attenuation for directional lights
|
||||
} else {
|
||||
//point light
|
||||
surfaceToLight = normalize(light.position.xyz - surfacePos);
|
||||
float distanceToLight = length(light.position.xyz - surfacePos);
|
||||
attenuation = 1.0 / (1.0 + light.attenuation * pow(distanceToLight, 2));
|
||||
|
||||
//cone restrictions (affects attenuation)
|
||||
float lightToSurfaceAngle = degrees(acos(dot(-surfaceToLight, normalize(light.coneDirection))));
|
||||
if(lightToSurfaceAngle > light.coneAngle){
|
||||
attenuation = 0.0;
|
||||
}
|
||||
}
|
||||
|
||||
//ambient
|
||||
vec3 ambient = light.ambientCoefficient * surfaceColor.rgb * light.intensities;
|
||||
|
||||
//diffuse
|
||||
float diffuseCoefficient = max(0.0, dot(normal, surfaceToLight));
|
||||
vec3 diffuse = diffuseCoefficient * surfaceColor.rgb * light.intensities;
|
||||
|
||||
//specular
|
||||
float specularCoefficient = 0.0;
|
||||
if(diffuseCoefficient > 0.0)
|
||||
specularCoefficient = pow(max(0.0, dot(surfaceToCamera, reflect(-surfaceToLight, normal))), materialShininess);
|
||||
vec3 specular = specularCoefficient * materialSpecularColor * light.intensities;
|
||||
|
||||
//linear color (color before gamma correction)
|
||||
return ambient + attenuation*(diffuse + specular);
|
||||
}
|
||||
|
||||
void main() {
|
||||
vec3 normal = normalize(transpose(inverse(mat3(transform))) * fragNormal);
|
||||
vec3 surfacePos = vec3(transform * vec4(fragVert, 1));
|
||||
vec4 surfaceColor = texture(materialTex, fragTexCoord);
|
||||
vec3 surfaceToCamera = normalize(cameraPosition - surfacePos);
|
||||
|
||||
//combine color from all the lights
|
||||
vec3 linearColor = vec3(0);
|
||||
for(int i = 0; i < numLights; ++i){
|
||||
linearColor += ApplyLight(allLights[i], surfaceColor.rgb, normal, surfacePos, surfaceToCamera);
|
||||
}
|
||||
|
||||
//final color (after gamma correction)
|
||||
vec3 gamma = vec3(1.0/2.2);
|
||||
finalColor = vec4(pow(linearColor, gamma), surfaceColor.a);
|
||||
}
|
Reference in a new issue