]> git.tdb.fi Git - libs/gl.git/blobdiff - shaderlib/cooktorrance.glsl
Add a tint property for PBR materials
[libs/gl.git] / shaderlib / cooktorrance.glsl
index fe6179b783ba27fc50fdb164e5e6ba30f3536832..8a69d473e83935adf8d8d866b2beab07518e22ea 100644 (file)
@@ -1,10 +1,12 @@
 import msp_interface;
 import common;
+import environment;
 import shadow;
 
 struct PbrMaterialParameters
 {
        vec4 base_color;
+       vec4 tint;
        vec4 emission;
        float metalness;
        float roughness;
@@ -13,7 +15,7 @@ struct PbrMaterialParameters
 layout(set=1) uniform PbrMaterial
 {
        PbrMaterialParameters pbr_material;
-       float alpha_cutoff;
+       AlphaCutoffParams alpha_cutoff;
 };
 
 layout(set=1) uniform sampler2D base_color_map;
@@ -30,15 +32,14 @@ layout(constant_id=auto) const bool use_occlusion_map = false;
 layout(constant_id=auto) const bool use_emission = false;
 layout(constant_id=auto) const bool use_emission_map = false;
 layout(constant_id=auto) const bool use_image_based_lighting = false;
-layout(constant_id=auto) const bool use_alpha_cutoff = false;
 
 #pragma MSP stage(fragment)
 virtual vec4 get_base_color()
 {
        if(use_base_color_map)
-               return texture(base_color_map, texcoord.xy);
+               return texture(base_color_map, texcoord.xy)*pbr_material.tint;
        else
-               return pbr_material.base_color;
+               return pbr_material.base_color*pbr_material.tint;
 }
 
 virtual float get_metalness_value()
@@ -176,8 +177,7 @@ vec3 cooktorrance_lighting(vec3 normal, vec3 look, vec3 base_color, float metaln
 void main()
 {
        vec4 base_color = get_base_color();
-       if(use_alpha_cutoff && base_color.a<alpha_cutoff)
-               discard;
+       float alpha = apply_alpha_cutoff(base_color.a, alpha_cutoff);
 
        vec3 normal = get_fragment_normal();
        vec3 look = normalize(world_look_dir);
@@ -187,5 +187,5 @@ void main()
 
        vec3 lit_color = cooktorrance_lighting(normal, look, base_color.rgb, metalness, roughness);
 
-       frag_color = vec4(lit_color, base_color.a);
+       frag_color = vec4(lit_color, alpha);
 }