adding pbr shader for plants.......?...?..?
This commit is contained in:
parent
6e525f8a6e
commit
cb7385bc1b
@ -1,9 +1,15 @@
|
|||||||
#version 430 core
|
#version 430 core
|
||||||
|
#define PI 3.14159265359
|
||||||
|
|
||||||
float AMBIENT = 0.1;
|
float AMBIENT = 0.1;
|
||||||
|
|
||||||
|
uniform vec3 albedo;
|
||||||
|
uniform float metallic;
|
||||||
|
uniform float roughness;
|
||||||
uniform vec3 color;
|
uniform vec3 color;
|
||||||
uniform vec3 lightPos;
|
uniform vec3 lightPos;
|
||||||
|
uniform vec3 viewPos;
|
||||||
|
uniform vec3 ambientColor;
|
||||||
uniform sampler2D colorTexture;
|
uniform sampler2D colorTexture;
|
||||||
|
|
||||||
in vec3 fragNormal;
|
in vec3 fragNormal;
|
||||||
@ -12,40 +18,55 @@ in vec2 texCoords;
|
|||||||
|
|
||||||
out vec4 outColor;
|
out vec4 outColor;
|
||||||
|
|
||||||
uniform float shininess;
|
float specularD(float NdotH, float roughness)
|
||||||
uniform vec3 ambientColor;
|
{
|
||||||
uniform vec3 specularColor;
|
float alpha = roughness * roughness;
|
||||||
uniform vec3 emissiveColor;
|
float alpha2 = alpha * alpha;
|
||||||
uniform float opticalDensity;
|
float cos2ThetaH = NdotH * NdotH;
|
||||||
uniform float dissolve;
|
|
||||||
uniform int illuminationModel;
|
float expTerm = (cos2ThetaH - 1.0) / (alpha2 * cos2ThetaH);
|
||||||
|
return exp(expTerm) / (PI * alpha2 * pow(cos2ThetaH + alpha2 - 1.0, 2.0));
|
||||||
|
}
|
||||||
|
|
||||||
|
vec3 specularF(float LdotH, vec3 F0)
|
||||||
|
{
|
||||||
|
return F0 + (vec3(1.0) - F0) * pow(1.0 - LdotH, 5.0);
|
||||||
|
}
|
||||||
|
|
||||||
|
float specularG(float NdotL, float NdotV, float roughness)
|
||||||
|
{
|
||||||
|
float k = (roughness + 1.0) * (roughness + 1.0) / 8.0;
|
||||||
|
|
||||||
|
float GL = NdotL / (NdotL * (1.0 - k) + k);
|
||||||
|
float GV = NdotV / (NdotV * (1.0 - k) + k);
|
||||||
|
|
||||||
|
return GL * GV;
|
||||||
|
}
|
||||||
|
|
||||||
void main()
|
void main()
|
||||||
{
|
{
|
||||||
vec3 lightDir = normalize(lightPos - fragPosition);
|
|
||||||
vec3 normal = normalize(fragNormal);
|
vec3 normal = normalize(fragNormal);
|
||||||
float diffuse = max(0.0, dot(normal, lightDir));
|
vec3 viewDir = normalize(viewPos - fragPosition);
|
||||||
|
vec3 lightDir = normalize(lightPos - fragPosition);
|
||||||
|
|
||||||
|
vec3 F0 = vec3(0.04);
|
||||||
vec3 lambertian = texture(colorTexture, texCoords).rgb * diffuse;
|
F0 = mix(F0, albedo, metallic);
|
||||||
|
|
||||||
|
float NdotL = max(dot(normal, lightDir), 0.0);
|
||||||
vec3 viewDir = normalize(-fragPosition);
|
float NdotV = max(dot(normal, viewDir), 0.0);
|
||||||
vec3 halfwayDir = normalize(lightDir + viewDir);
|
|
||||||
float specular = pow(max(0.0, dot(normal, halfwayDir)), shininess);
|
|
||||||
vec3 blinnPhong = specularColor * specular;
|
|
||||||
|
|
||||||
|
vec3 H = normalize(lightDir + viewDir);
|
||||||
vec3 emissive = emissiveColor;
|
float NdotH = max(dot(normal, H), 0.0);
|
||||||
|
float LdotH = max(dot(lightDir, H), 0.0);
|
||||||
|
vec3 albedo = texture(colorTexture, texCoords).rgb;
|
||||||
|
albedo *= 2.0;
|
||||||
|
vec3 specular = F0 * (specularD(NdotH, roughness) * specularF(LdotH, F0) * specularG(NdotL, NdotV, roughness)) / (4.0 * NdotL * NdotV);
|
||||||
|
|
||||||
|
vec3 diffuse = (1.0 - F0) * albedo / PI;
|
||||||
|
|
||||||
vec3 ambient = ambientColor * AMBIENT;
|
vec3 ambient = ambientColor * AMBIENT;
|
||||||
|
|
||||||
|
vec3 finalColor = ambient + (diffuse + specular) * NdotL;
|
||||||
vec3 finalColor = lambertian + blinnPhong + emissive + ambient;
|
|
||||||
|
|
||||||
|
|
||||||
finalColor *= (1.0 - dissolve);
|
|
||||||
|
|
||||||
outColor = vec4(finalColor, 1.0);
|
outColor = vec4(finalColor, 1.0);
|
||||||
}
|
}
|
||||||
|
@ -399,7 +399,8 @@ void drawObjectTexture_plant(Core::RenderContext& context, glm::mat4 modelMatrix
|
|||||||
glUniform1f(glGetUniformLocation(program, "opticalDensity"), material.Ni);
|
glUniform1f(glGetUniformLocation(program, "opticalDensity"), material.Ni);
|
||||||
//glUniform1f(glGetUniformLocation(program, "dissolve"), material.d);
|
//glUniform1f(glGetUniformLocation(program, "dissolve"), material.d);
|
||||||
glUniform1i(glGetUniformLocation(program, "illuminationModel"), material.illum);
|
glUniform1i(glGetUniformLocation(program, "illuminationModel"), material.illum);
|
||||||
|
glUniform1f(glGetUniformLocation(program, "metallic"), 0.05);
|
||||||
|
glUniform1f(glGetUniformLocation(program, "roughness"), 0.2);
|
||||||
Core::DrawContext(context);
|
Core::DrawContext(context);
|
||||||
glUseProgram(0);
|
glUseProgram(0);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user