|
|
请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!
您需要 登录 才可以下载或查看,没有账号?注册
x
- ^* X* r5 p, A/ O% k( W0 H( s
+ K# q& D \0 Z1 N官方提供的实例如下 5 `' j$ K$ z) h: e4 F l* A
" s: t! D9 H( {( Z( e5 d1。 首先在Scene里面激活 渲染 ShadowMap0 }8 q$ P9 U" h( v
//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% m; f' z( f- C, Y7 Q) T4 @
4 C9 U% n2 |) A5 C8 u# J2。 创建平行光,并可以投射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 );/ F6 j: x3 u o4 Q
* O- D: Z) e! D' t8 |6 N' c& n//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
# `4 u) T" x2 L7 `. M9 P2 E! O3 Z7 L% H# a0 F: e" Y! F
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 );
& {$ `6 A3 l7 f/ c" y/ E# x$ q, X. E; K: p
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 );
% v5 L1 F+ C: K% F# Z
; h* R- h. m* B" T$ b6 Q' l. S1 z$ o0 j4 `( b. i: F
( S# e: _. U2 U! ?8 N! ]& u4 G- a O
效果如下!: u6 R& A( X1 V1 _ J
0 _! W% F$ ], D3 L- @, l/ `$ y8 d. a/ U+ @. E; ^4 G
W: r- E% }4 s
|
|