summaryrefslogtreecommitdiff
path: root/indra/newview/app_settings/shaders/class2
diff options
context:
space:
mode:
authorDave Parks <davep@lindenlab.com>2023-02-06 10:28:26 -0600
committerDave Parks <davep@lindenlab.com>2023-02-06 10:28:26 -0600
commitc8fb3ad4de0575a0538b9532e819319f655613d1 (patch)
tree212fe0ce88b974efb9893f9261f97f5f2747b4d4 /indra/newview/app_settings/shaders/class2
parent9b9f8116c5e10de4ee7187a5ee08fd057192c602 (diff)
SL-19148 Decruft followthrough -- fix for crash when running from installer. Feed fresnel component into PBR alpha. Remove obsolete "shader_hierarchy.txt", remove redundant LL_PROFILE_ZONE_SCOPED, remove unused shader feature flag.
Diffstat (limited to 'indra/newview/app_settings/shaders/class2')
-rw-r--r--indra/newview/app_settings/shaders/class2/deferred/pbralphaF.glsl14
1 files changed, 13 insertions, 1 deletions
diff --git a/indra/newview/app_settings/shaders/class2/deferred/pbralphaF.glsl b/indra/newview/app_settings/shaders/class2/deferred/pbralphaF.glsl
index ccf20942e3..35e22ef3a2 100644
--- a/indra/newview/app_settings/shaders/class2/deferred/pbralphaF.glsl
+++ b/indra/newview/app_settings/shaders/class2/deferred/pbralphaF.glsl
@@ -113,6 +113,8 @@ vec3 pbrPunctual(vec3 diffuseColor, vec3 specularColor,
vec3 v, // surface point to camera
vec3 l); //surface point to light
+vec2 BRDF(float NoV, float roughness);
+
vec3 calcPointLightOrSpotLight(vec3 diffuseColor, vec3 specularColor,
float perceptualRoughness,
float metallic,
@@ -217,8 +219,12 @@ void main()
calcDiffuseSpecular(col.rgb, metallic, diffuseColor, specularColor);
vec3 v = -normalize(pos.xyz);
+
color = pbrBaseLight(diffuseColor, specularColor, metallic, v, norm.xyz, perceptualRoughness, light_dir, sunlit, scol, radiance, irradiance, colorEmissive, ao, additive, atten);
+ float nv = clamp(abs(dot(norm.xyz, v)), 0.001, 1.0);
+ vec2 brdf = BRDF(clamp(nv, 0, 1), 1.0-perceptualRoughness);
+
vec3 light = vec3(0);
// Punctual lights
@@ -235,5 +241,11 @@ void main()
color.rgb += light.rgb;
- frag_color = vec4(color.rgb,basecolor.a * vertex_color.a);
+ float a = basecolor.a*vertex_color.a;
+ vec3 spec = radiance; // *specularColor;
+ float lum = max(max(spec.r, spec.g), spec.b);
+
+ float f = brdf.y;
+ a += f;
+ frag_color = vec4(color.rgb,a);
}