From d52654dfdbe16345023fed4c61261dc4c66b96fe Mon Sep 17 00:00:00 2001 From: Omniscient Date: Sat, 15 Jun 2024 22:20:15 +1000 Subject: trying to figure out uniform structs.. --- assets/shaders/pbr_params.frag | 68 +++++++++++++++++++++--------------------- assets/shaders/pbr_params.vert | 3 +- 2 files changed, 36 insertions(+), 35 deletions(-) (limited to 'assets/shaders') diff --git a/assets/shaders/pbr_params.frag b/assets/shaders/pbr_params.frag index 068fb3c..88cbd0d 100644 --- a/assets/shaders/pbr_params.frag +++ b/assets/shaders/pbr_params.frag @@ -12,12 +12,6 @@ struct PointLight { }; // --- Uniforms -// Lights data -#define NUM_POINT_LIGHTS 4 -uniform Scene_Lights { - vec3 viewPos; - PointLight pointLights[NUM_POINT_LIGHTS]; -} scene; // Material properties uniform PBR_Params { uniform vec3 albedo; @@ -25,6 +19,12 @@ uniform PBR_Params { uniform float roughness; uniform float ao; } pbr; +// Lights data +#define NUM_POINT_LIGHTS 4 +uniform Scene_Lights { + vec3 viewPos; + // PointLight pointLights[NUM_POINT_LIGHTS]; +} scene; const float PI = 3.14; @@ -42,39 +42,39 @@ void main() { F0 = mix(F0, pbr.albedo, pbr.metallic); vec3 Lo = vec3(0.0); // denoted L in the radiance equation - for (int i = 0; i < 4; i++) { - vec3 lightVec = normalize(scene.pointLights[i].position - fragWorldPos); - vec3 halfway = normalize(viewDir + lightVec); - float distance = length(scene.pointLights[i].position - fragWorldPos); - float attenuation = 1.0 / (distance * distance); - vec3 radiance = scene.pointLights[i].color * attenuation; - - // cook-torrance brdf - float NDF = DistributionGGX(norm, halfway, pbr.roughness); - float G = GeometrySmith(norm, viewDir, lightVec, pbr.roughness); - vec3 F = fresnelSchlick(max(dot(halfway, viewDir), 0.0), F0); - - vec3 kS = F; - vec3 kD = vec3(1.0) - kS; - kD *= 1.0 - pbr.metallic; - - vec3 numerator = NDF * G * F; - float denominator = 4.0 * max(dot(norm, viewDir), 0.0) * max(dot(norm, lightVec), 0.0) + 0.0001; - vec3 specular = numerator / denominator; - - // add to outgoing radiance Lo - float NdotL = max(dot(norm, lightVec), 0.0); - Lo += (kD * pbr.albedo / PI + specular) * radiance * NdotL; - } + // for (int i = 0; i < 4; i++) { + // vec3 lightVec = normalize(scene.pointLights[i].position - fragWorldPos); + // vec3 halfway = normalize(viewDir + lightVec); + // float distance = length(scene.pointLights[i].position - fragWorldPos); + // float attenuation = 1.0 / (distance * distance); + // vec3 radiance = scene.pointLights[i].color * attenuation; + + // // cook-torrance brdf + // float NDF = DistributionGGX(norm, halfway, pbr.roughness); + // float G = GeometrySmith(norm, viewDir, lightVec, pbr.roughness); + // vec3 F = fresnelSchlick(max(dot(halfway, viewDir), 0.0), F0); + + // vec3 kS = F; + // vec3 kD = vec3(1.0) - kS; + // kD *= 1.0 - pbr.metallic; + + // vec3 numerator = NDF * G * F; + // float denominator = 4.0 * max(dot(norm, viewDir), 0.0) * max(dot(norm, lightVec), 0.0) + 0.0001; + // vec3 specular = numerator / denominator; + + // // add to outgoing radiance Lo + // float NdotL = max(dot(norm, lightVec), 0.0); + // Lo += (kD * pbr.albedo / PI + specular) * radiance * NdotL; + // } vec3 ambient = vec3(0.03) * pbr.albedo * pbr.ao; vec3 color = ambient + Lo; - // color = color / (color + vec3(1.0)); - // color = pow(color, vec3(1.0/2.2)); + color = color / (color + vec3(1.0)); + color = pow(color, vec3(1.0/2.2)); - // FragColor = vec4(color, 1.0); - FragColor = vec4(1.0); + FragColor = vec4(scene.viewPos, 1.0); + // FragColor = vec4(1.0); } /* The below are from https://learnopengl.com/PBR/Lighting */ diff --git a/assets/shaders/pbr_params.vert b/assets/shaders/pbr_params.vert index e3cbe96..01379d7 100644 --- a/assets/shaders/pbr_params.vert +++ b/assets/shaders/pbr_params.vert @@ -19,7 +19,8 @@ layout(location = 2) out vec2 fragTexCoords; void main() { fragWorldPos = vec3(mvp.model * vec4(inPosition, 1.0)); - // TODO: fragNormal + mat3 normalMatrix = transpose(inverse(mat3(mvp.model))); + fragNormal = normalMatrix * inNormal; fragTexCoords = inTexCoords; gl_Position = mvp.proj * mvp.view * mvp.model * vec4(inPosition, 1.0); -- cgit v1.2.3-70-g09d2