From 3d8787db860e143b08d4c1eff0f9b009997023a2 Mon Sep 17 00:00:00 2001 From: George Corney Date: Mon, 25 Oct 2021 20:46:46 +0100 Subject: [PATCH 1/2] Expose getTransmissionRenderTarget() --- src/renderers/WebGLRenderer.js | 48 ++++++++++++++++++++-------------- 1 file changed, 28 insertions(+), 20 deletions(-) diff --git a/src/renderers/WebGLRenderer.js b/src/renderers/WebGLRenderer.js index 805c20cd349ab5..4d7f9e23fb8b46 100644 --- a/src/renderers/WebGLRenderer.js +++ b/src/renderers/WebGLRenderer.js @@ -9,7 +9,7 @@ import { LinearEncoding, NoToneMapping, LinearMipmapLinearFilter, - NearestFilter, + LinearFilter, ClampToEdgeWrapping } from '../constants.js'; import { Frustum } from '../math/Frustum.js'; @@ -556,6 +556,28 @@ function WebGLRenderer( parameters = {} ) { }; + this.getTransmissionRenderTarget = function () { + + if ( _transmissionRenderTarget === null ) { + + const needsAntialias = _antialias === true && capabilities.isWebGL2 === true; + const renderTargetType = needsAntialias ? WebGLMultisampleRenderTarget : WebGLRenderTarget; + + _transmissionRenderTarget = new renderTargetType( 1024, 1024, { + generateMipmaps: true, + type: utils.convert( HalfFloatType ) !== null ? HalfFloatType : UnsignedByteType, + minFilter: LinearMipmapLinearFilter, + magFilter: LinearFilter, + wrapS: ClampToEdgeWrapping, + wrapT: ClampToEdgeWrapping + } ); + + } + + return _transmissionRenderTarget; + + } + // this.dispose = function () { @@ -1181,24 +1203,10 @@ function WebGLRenderer( parameters = {} ) { function renderTransmissionPass( opaqueObjects, scene, camera ) { - if ( _transmissionRenderTarget === null ) { - - const needsAntialias = _antialias === true && capabilities.isWebGL2 === true; - const renderTargetType = needsAntialias ? WebGLMultisampleRenderTarget : WebGLRenderTarget; - - _transmissionRenderTarget = new renderTargetType( 1024, 1024, { - generateMipmaps: true, - type: utils.convert( HalfFloatType ) !== null ? HalfFloatType : UnsignedByteType, - minFilter: LinearMipmapLinearFilter, - magFilter: NearestFilter, - wrapS: ClampToEdgeWrapping, - wrapT: ClampToEdgeWrapping - } ); - - } + const transmissionRenderTarget = _this.getTransmissionRenderTarget(); const currentRenderTarget = _this.getRenderTarget(); - _this.setRenderTarget( _transmissionRenderTarget ); + _this.setRenderTarget( transmissionRenderTarget ); _this.clear(); // Turn off the features which can affect the frag color for opaque objects pass. @@ -1210,8 +1218,8 @@ function WebGLRenderer( parameters = {} ) { _this.toneMapping = currentToneMapping; - textures.updateMultisampleRenderTarget( _transmissionRenderTarget ); - textures.updateRenderTargetMipmap( _transmissionRenderTarget ); + textures.updateMultisampleRenderTarget( transmissionRenderTarget ); + textures.updateRenderTargetMipmap( transmissionRenderTarget ); _this.setRenderTarget( currentRenderTarget ); @@ -1685,7 +1693,7 @@ function WebGLRenderer( parameters = {} ) { } - materials.refreshMaterialUniforms( m_uniforms, material, _pixelRatio, _height, _transmissionRenderTarget ); + materials.refreshMaterialUniforms( m_uniforms, material, _pixelRatio, _height, _this.getTransmissionRenderTarget() ); WebGLUniforms.upload( _gl, materialProperties.uniformsList, m_uniforms, textures ); From 603cb5b33e2de8dc8ecdf239e7c18958fe259613 Mon Sep 17 00:00:00 2001 From: George Corney Date: Mon, 25 Oct 2021 20:50:08 +0100 Subject: [PATCH 2/2] Linter appeasement --- src/renderers/WebGLRenderer.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/renderers/WebGLRenderer.js b/src/renderers/WebGLRenderer.js index 4d7f9e23fb8b46..5a2935124f637c 100644 --- a/src/renderers/WebGLRenderer.js +++ b/src/renderers/WebGLRenderer.js @@ -576,7 +576,7 @@ function WebGLRenderer( parameters = {} ) { return _transmissionRenderTarget; - } + }; //