|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
+ X$ T1 h- \& W5 N
8 F6 F, ?, \! t8 J+ v" Y, e, T( Y# _官方提供的实例如下 % \& D9 f( k8 Q6 m
* w1 k! I3 D+ W- k0 y- V2 X m+ k1。 首先在Scene里面激活 渲染 ShadowMap
! |6 Q% h, ?4 k. R//Create a WebGLRenderer and turn on shadows in the renderervar renderer = new THREE.WebGLRenderer();renderer.shadowMap.enabled = true;renderer.shadowMap.type = THREE.PCFSoftShadowMap; // default THREE.PCFShadowMap
! S, A% j* m! j" [5 D7 V( L. G. @ Y. O" @* ^; H! `# K6 M
2。 创建平行光,并可以投射Shadow//Create a DirectionalLight and turn on shadows for the lightvar light = new THREE.DirectionalLight( 0xffffff, 1, 100 );light.position.set( 0, 1, 0 ); //default; light shining from toplight.castShadow = true; // default falsescene.add( light );4 [: {$ E* ^2 `2 w M
3 x/ t/ @9 N: x+ s- X- i0 _ A//Set up shadow properties for the lightlight.shadow.mapSize.width = 512; // defaultlight.shadow.mapSize.height = 512; // defaultlight.shadow.camera.near = 0.5; // defaultlight.shadow.camera.far = 500; // default+ \% m* g7 e# v/ V% N
" Z8 z4 q; n- _7 ~
3. 创建接受shadow的物体 //Create a sphere that cast shadows (but does not receive them)var sphereGeometry = new THREE.SphereBufferGeometry( 5, 32, 32 );var sphereMaterial = new THREE.MeshStandardMaterial( { color: 0xff0000 } );var sphere = new THREE.Mesh( sphereGeometry, sphereMaterial );sphere.castShadow = true; //default is falsesphere.receiveShadow = false; //defaultscene.add( sphere );
) _, I; Z6 |, v0 Q$ U0 R2 q' P$ j8 _4 d
4. 创建获取投影的平面 //Create a plane that receives shadows (but does not cast them)var planeGeometry = new THREE.PlaneBufferGeometry( 20, 20, 32, 32 );var planeMaterial = new THREE.MeshStandardMaterial( { color: 0x00ff00 } )var plane = new THREE.Mesh( planeGeometry, planeMaterial );plane.receiveShadow = true;scene.add( plane );//Create a helper for the shadow camera (optional)var helper = new THREE.CameraHelper( light.shadow.camera );scene.add( helper );' b9 r/ F' B: L2 E* Z" Z
4 ~" I0 \0 S$ v0 E! |7 |* o9 r. ^% V6 \
- e. ]" u" x; J. L
% Q* h$ y# O2 f1 k
效果如下!
4 H6 @* p* P' g2 F6 C. C8 G+ y# G6 f
0 u. }+ Z$ Z$ L. W2 s$ r, j3 {1 X! Y+ c
6 q8 t3 d- t8 L) ]& D% T |
|