Based on http://jcgt.org/published/0008/01/03/ This is a simple trick that does *not* have a huge performance impact but does work pretty well. It just modifies the Fresnel term to account for the multibounce energy loss (coloration). However this makes the shader variations count double. To avoid this we use a uniform and pass the multiscatter use flag inside the sign of f90. This is a bit hacky but avoids many code duplication. This uses the simplification proposed by McAuley in A Journey Through Implementing Multiscattering BRDFs and Area Lights This does not handle area light differently than the IBL case but that's already an issue in current implementation. This is related to T68460. Reviewed By: brecht Differential Revision: https://developer.blender.org/D8912
		
			
				
	
	
		
			25 lines
		
	
	
		
			923 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
			
		
		
	
	
			25 lines
		
	
	
		
			923 B
		
	
	
	
		
			GLSL
		
	
	
	
	
	
| #ifndef VOLUMETRICS
 | |
| void node_bsdf_glossy(
 | |
|     vec4 color, float roughness, vec3 N, float use_multiscatter, float ssr_id, out Closure result)
 | |
| {
 | |
|   N = normalize(N);
 | |
|   vec3 out_spec, ssr_spec;
 | |
|   eevee_closure_glossy(N,
 | |
|                        vec3(1.0),
 | |
|                        use_multiscatter != 0.0 ? vec3(1.0) : vec3(-1.0), /* HACK */
 | |
|                        int(ssr_id),
 | |
|                        roughness,
 | |
|                        1.0,
 | |
|                        true,
 | |
|                        out_spec,
 | |
|                        ssr_spec);
 | |
|   vec3 vN = mat3(ViewMatrix) * N;
 | |
|   result = CLOSURE_DEFAULT;
 | |
|   result.radiance = render_pass_glossy_mask(vec3(1.0), out_spec) * color.rgb;
 | |
|   closure_load_ssr_data(ssr_spec * color.rgb, roughness, N, viewCameraVec, int(ssr_id), result);
 | |
| }
 | |
| #else
 | |
| /* Stub glossy because it is not compatible with volumetrics. */
 | |
| #  define node_bsdf_glossy(a, b, c, d, e, result) (result = CLOSURE_DEFAULT)
 | |
| #endif
 |