90 lines
2.5 KiB
GLSL
90 lines
2.5 KiB
GLSL
#version 450 core
|
|
#extension GL_ARB_shading_language_include : require
|
|
#include "../../lib/lights.fs"
|
|
#include "../../lib/material.fs"
|
|
|
|
//foliage.fs
|
|
|
|
layout (location = 0) out vec4 accum;
|
|
layout (location = 1) out float reveal;
|
|
|
|
|
|
|
|
|
|
in vec3 FragPos;
|
|
in vec3 ViewFragPos;
|
|
in vec3 Normal;
|
|
in vec2 TexCoord;
|
|
in vec4 FragPosLightSpace;
|
|
in vec4 instanceColor;
|
|
|
|
|
|
uniform dvec3 viewPos;
|
|
uniform Material material;
|
|
uniform mat4 view;
|
|
|
|
|
|
/**
|
|
The output
|
|
*/
|
|
out vec4 FragColor;
|
|
|
|
// function prototypes
|
|
float easeIn(float interpolator);
|
|
float easeOut(float interpolator);
|
|
|
|
void main(){
|
|
vec3 viewDir = normalize(vec3(viewPos) - FragPos);
|
|
|
|
//grab light intensity
|
|
vec3 lightIntensity = vec3(calcLightIntensityTotal(Normal));
|
|
|
|
//get color of base texture
|
|
// vec3 textureColor = vec3((norm.x + 1) / 2.0, norm.y, 1.0 - (norm.x + 1) / 2.0);
|
|
vec4 textureColor = texture(material.diffuse,TexCoord) * instanceColor;
|
|
// vec3 textureColor = vec3(0.17647,0.4,0.09411);//texture(material.diffuse, TexCoord).rgb;
|
|
|
|
//shadow
|
|
float shadow = ShadowCalculation(FragPosLightSpace, normalize(-directLight.direction), Normal);
|
|
|
|
//
|
|
//point light calculations
|
|
uint clusterIndex = findCluster(ViewFragPos, zNear, zFar);
|
|
uint pointLightCount = clusters[clusterIndex].count;
|
|
for(int i = 0; i < pointLightCount; i++){
|
|
uint pointLightIndex = clusters[clusterIndex].lightIndices[i];
|
|
PointLight pointLight = pointLight[pointLightIndex];
|
|
lightIntensity = lightIntensity + CalcPointLight(pointLight, Normal, FragPos, viewDir);
|
|
}
|
|
//error checking on light clusters
|
|
if(pointLightCount > MAX_LIGHTS_PER_CLUSTER){
|
|
accum = vec4(1.0f,0.0f,0.0f,1);
|
|
reveal = textureColor.a;
|
|
return;
|
|
}
|
|
|
|
//calculate final color
|
|
vec4 finalColor = textureColor.rgba * vec4(lightIntensity,1.0);// * max(shadow,0.4);
|
|
// vec3 lightAmount = CalcDirLight(norm, viewDir);
|
|
// for(int i = 0; i < NR_POINT_LIGHTS; i++){
|
|
// lightAmount += CalcPointLight(i, norm, FragPos, viewDir);
|
|
// }
|
|
|
|
//calculate weight function
|
|
float weight = clamp(pow(min(1.0, finalColor.a * 10.0) + 0.01, 3.0) * 1e3 *
|
|
pow(1.0 - gl_FragCoord.z * 0.9, 3.0), 1e-2, 3e3);
|
|
|
|
//emit colors
|
|
accum = vec4(finalColor.rgb * finalColor.a, finalColor.a) * weight;
|
|
// accum = finalColor * weight;
|
|
reveal = finalColor.a;
|
|
}
|
|
|
|
|
|
float easeIn(float interpolator){
|
|
return interpolator * interpolator;
|
|
}
|
|
|
|
float easeOut(float interpolator){
|
|
return 1 - easeIn(1 - interpolator);
|
|
} |