Skip to content

Commit

Permalink
WebGPURenderer: Add shadowNode to NodeMaterial - discard/opacity/co…
Browse files Browse the repository at this point in the history
…lor (#27625)

* add custom shadownode

* cleanup example

* update screenshot

* use node material instead

* shadow color and opacity

* update non-shadowNode materials

* updates

* Update webgpu_shadowmap.jpg

* update

---------

Co-authored-by: sunag <sunagbrasil@gmail.com>
  • Loading branch information
RenaudRohlinger and sunag authored Jan 27, 2024
1 parent 687bb04 commit 964d35d
Show file tree
Hide file tree
Showing 5 changed files with 48 additions and 6 deletions.
7 changes: 5 additions & 2 deletions examples/jsm/nodes/lighting/AnalyticLightNode.js
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,8 @@ class AnalyticLightNode extends LightingNode {
if ( overrideMaterial === null ) {

overrideMaterial = builder.createNodeMaterial();
overrideMaterial.fragmentNode = vec4( 1 );
overrideMaterial.fragmentNode = vec4( 0, 0, 0, 1 );
overrideMaterial.isShadowNodeMaterial = true; // Use to avoid other overrideMaterial override material.fragmentNode unintentionally when using material.shadowNode

}

Expand Down Expand Up @@ -147,8 +148,10 @@ class AnalyticLightNode extends LightingNode {
*/
//

const shadowColor = texture( rtt.texture, shadowCoord );

this.rtt = rtt;
this.colorNode = this.colorNode.mul( frustumTest.mix( 1, shadowNode ) );
this.colorNode = this.colorNode.mul( frustumTest.mix( 1, shadowNode.mix( shadowColor.a.mix( 1, shadowColor ), 1 ) ) );

this.shadowNode = shadowNode;

Expand Down
2 changes: 2 additions & 0 deletions examples/jsm/nodes/materials/NodeMaterial.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ class NodeMaterial extends ShaderMaterial {
this.positionNode = null;

this.depthNode = null;
this.shadowNode = null;

this.outputNode = null;

Expand Down Expand Up @@ -496,6 +497,7 @@ class NodeMaterial extends ShaderMaterial {
this.positionNode = source.positionNode;

this.depthNode = source.depthNode;
this.shadowNode = source.shadowNode;

this.outputNode = source.outputNode;

Expand Down
14 changes: 14 additions & 0 deletions examples/jsm/renderers/common/Renderer.js
Original file line number Diff line number Diff line change
Expand Up @@ -1085,6 +1085,7 @@ class Renderer {
renderObject( object, scene, camera, geometry, material, group, lightsNode ) {

let overridePositionNode;
let overrideFragmentNode;

//

Expand All @@ -1106,6 +1107,13 @@ class Renderer {

}

if ( overrideMaterial.isShadowNodeMaterial && ( material.shadowNode && material.shadowNode.isNode ) ) {

overrideFragmentNode = overrideMaterial.fragmentNode;
overrideMaterial.fragmentNode = material.shadowNode;

}

material = overrideMaterial;

}
Expand Down Expand Up @@ -1136,6 +1144,12 @@ class Renderer {

}

if ( overrideFragmentNode !== undefined ) {

scene.overrideMaterial.fragmentNode = overrideFragmentNode;

}

//

object.onAfterRender( this, scene, camera, geometry, material, group );
Expand Down
Binary file modified examples/screenshots/webgpu_shadowmap.jpg
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
31 changes: 27 additions & 4 deletions examples/webgpu_shadowmap.html
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@
import WebGPURenderer from 'three/addons/renderers/webgpu/WebGPURenderer.js';

import { OrbitControls } from 'three/addons/controls/OrbitControls.js';

import { vec4, tslFn, vertexIndex, MeshPhongNodeMaterial } from 'three/nodes';
let camera, scene, renderer, clock;
let dirLight, spotLight;
let torusKnot, dirGroup;
Expand Down Expand Up @@ -93,14 +93,37 @@

// geometry

const geometry = new THREE.TorusKnotGeometry( 25, 8, 75, 20 );
const material = new THREE.MeshPhongMaterial( {
const geometry = new THREE.TorusKnotGeometry( 25, 8, 75, 80 );
const material = new MeshPhongNodeMaterial( {
color: 0x999999,
shininess: 0,
specular: 0x222222
} );

torusKnot = new THREE.Mesh( geometry, material );
const materialCustomShadow = material.clone();
materialCustomShadow.transparent = true;

const materialColor = vec4( 1, 0, 1, .5 );

const discardNode = vertexIndex.hash().greaterThan( 0.5 );

materialCustomShadow.colorNode = tslFn( () => {

discardNode.discard();

return materialColor;

} )();

materialCustomShadow.shadowNode = tslFn( () => {

discardNode.discard();

return materialColor;

} )();

torusKnot = new THREE.Mesh( geometry, materialCustomShadow );
torusKnot.scale.multiplyScalar( 1 / 18 );
torusKnot.position.y = 3;
torusKnot.castShadow = true;
Expand Down

0 comments on commit 964d35d

Please sign in to comment.