[Bf-blender-cvs] [87adeb8dd91] blender2.8: Eevee: Ambient Occlusion: Enable Multibounce approximation and Change influence factor.

Clément Foucault noreply at git.blender.org
Thu Jun 22 04:01:12 CEST 2017


Commit: 87adeb8dd91db5bfada04f6df749c28cc4b79251
Author: Clément Foucault
Date:   Thu Jun 22 03:50:50 2017 +0200
Branches: blender2.8
https://developer.blender.org/rB87adeb8dd91db5bfada04f6df749c28cc4b79251

Eevee: Ambient Occlusion: Enable Multibounce approximation and Change influence factor.

Making the influence a power for easy tuning. Works like a contrast knob.

===================================================================

M	source/blender/draw/engines/eevee/eevee_effects.c
M	source/blender/draw/engines/eevee/shaders/ambient_occlusion_lib.glsl
M	source/blender/draw/engines/eevee/shaders/lit_surface_frag.glsl

===================================================================

diff --git a/source/blender/draw/engines/eevee/eevee_effects.c b/source/blender/draw/engines/eevee/eevee_effects.c
index 0aa72f6bc2c..b02109960c5 100644
--- a/source/blender/draw/engines/eevee/eevee_effects.c
+++ b/source/blender/draw/engines/eevee/eevee_effects.c
@@ -391,7 +391,7 @@ void EEVEE_effects_init(EEVEE_Data *vedata)
 		/* Ambient Occlusion*/
 		stl->effects->ao_dist = BKE_collection_engine_property_value_get_float(props, "gtao_distance");
 		stl->effects->ao_samples = BKE_collection_engine_property_value_get_int(props, "gtao_samples");
-		stl->effects->ao_factor = 1.0f - BKE_collection_engine_property_value_get_float(props, "gtao_factor");
+		stl->effects->ao_factor = BKE_collection_engine_property_value_get_float(props, "gtao_factor");
 	}
 
 	/* MinMax Pyramid */
diff --git a/source/blender/draw/engines/eevee/shaders/ambient_occlusion_lib.glsl b/source/blender/draw/engines/eevee/shaders/ambient_occlusion_lib.glsl
index a3a1d989475..65ff09c4eae 100644
--- a/source/blender/draw/engines/eevee/shaders/ambient_occlusion_lib.glsl
+++ b/source/blender/draw/engines/eevee/shaders/ambient_occlusion_lib.glsl
@@ -124,7 +124,7 @@ void gtao(vec3 normal, vec3 position, vec2 noise, out float visibility
 #endif
 	}
 
-	visibility = min(1.0, visibility / aoSamples);
+	visibility = clamp(visibility / aoSamples, 1e-8, 1.0);
 
 #ifdef USE_BENT_NORMAL
 	/* The bent normal will show the facet look of the mesh. Try to minimize this. */
@@ -132,7 +132,7 @@ void gtao(vec3 normal, vec3 position, vec2 noise, out float visibility
 #endif
 
 	/* Scale by user factor */
-	visibility = max(0.0, mix(aoFactor, 1.0, visibility));
+	visibility = pow(visibility, aoFactor);
 }
 
 /* Multibounce approximation base on surface albedo.
diff --git a/source/blender/draw/engines/eevee/shaders/lit_surface_frag.glsl b/source/blender/draw/engines/eevee/shaders/lit_surface_frag.glsl
index 44bfc5353ea..21ca08e109c 100644
--- a/source/blender/draw/engines/eevee/shaders/lit_surface_frag.glsl
+++ b/source/blender/draw/engines/eevee/shaders/lit_surface_frag.glsl
@@ -494,7 +494,7 @@ vec3 eevee_surface_lit(vec3 world_normal, vec3 albedo, vec3 f0, float roughness,
 
 	vec3 indirect_radiance =
 	        spec_accum.rgb * F_ibl(f0, brdf_lut) * float(specToggle) * specular_occlusion(dot(sd.N, sd.V), final_ao, roughness) +
-	        diff_accum.rgb * albedo * final_ao;
+	        diff_accum.rgb * albedo * gtao_multibounce(final_ao, albedo);
 
 	return radiance + indirect_radiance;
 }




More information about the Bf-blender-cvs mailing list