全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

利用Three.js如何实现阴影效果实例代码

前言

众所周知作为webgl的插件,three.js肯定没有原生webgl那样,添加一个阴影这么费劲。所以,经过一小时的研究(笨人不聪明,已经是极限速度了)。终于将阴影效果做了出来,并且还发现一些容易犯错的地方。话不多说了,来一起看看详细的介绍吧。

先上效果图:

实现这个效果其实很简单,只需要设置几个属性就可以实现当前的效果。而上面的材质问题我将放到下一节:

(1)首先需要告诉渲染器我需要阴影,你给我生成阴影:

renderer.shadowMap.enabled = true; 

(2)然后告诉灯光,我需要阴影:

light.castShadow = true; 

(3)告诉模型哪些需要投射阴影:

//告诉球需要投射阴影 
 sphere.castShadow = true; 
//告诉立方体需要投射阴影 
 cube.castShadow = true; 

(4)最后告诉最底下的平面长方形你要接受阴影:

plane.receiveShadow = true; 

上面四步只要设置好了,就可以实现阴影的效果了。

注意事项:你的模型的材质一定要选择对灯光有反应的材质,要不然不会出现效果,就是因为这个问题导致好长时间没有整出来阴影。

案例全部代码:

<!DOCTYPE html> 
<html lang="en"> 
<head> 
 <meta charset="UTF-8"> 
 <title>Title</title> 
 <style type="text/css"> 
 html, body { 
  margin: 0; 
  height: 100%; 
 } 
 
 canvas { 
  display: block; 
 } 
 
 </style> 
</head> 
<body onload="draw();"> 
 
</body> 
<script src="build/three.js"></script> 
<script src="examples/js/controls/TrackballControls.js"></script> 
<script src="examples/js/libs/stats.min.js"></script> 
<script> 
 var renderer; 
 function initRender() { 
 renderer = new THREE.WebGLRenderer({antialias:true}); 
 renderer.setSize(window.innerWidth, window.innerHeight); 
 //告诉渲染器需要阴影效果 
 renderer.shadowMap.enabled = true; 
 renderer.shadowMap.type = THREE.PCFSoftShadowMap; // 默认的是,没有设置的这个清晰 THREE.PCFShadowMap 
 document.body.appendChild(renderer.domElement); 
 } 
 
 var camera; 
 function initCamera() { 
 camera = new THREE.PerspectiveCamera(45, window.innerWidth/window.innerHeight, 0.1, 1000); 
 camera.position.set(0, 40, 100); 
 camera.lookAt(new THREE.Vector3(0,0,0)); 
 } 
 
 var scene; 
 function initScene() { 
 scene = new THREE.Scene(); 
 } 
 
 var light; 
 function initLight() { 
 scene.add(new THREE.AmbientLight(0x444444)); 
 
 light = new THREE.SpotLight(0xffffff); 
 light.position.set(60,30,0); 
 
 //告诉平行光需要开启阴影投射 
 light.castShadow = true; 
 
 scene.add(light); 
 } 
 
 function initModel() { 
 //上面的球 
 var sphereGeometry = new THREE.SphereGeometry(5,20,20); 
 var sphereMaterial = new THREE.MeshStandardMaterial({color:0x7777ff}); 
 
 var sphere = new THREE.Mesh(sphereGeometry, sphereMaterial); 
 sphere.position.y = 5; 
 
 //告诉球需要投射阴影 
 sphere.castShadow = true; 
 
 scene.add(sphere); 
 
 //辅助工具 
 var helper = new THREE.AxisHelper(10); 
 scene.add(helper); 
 
 //立方体 
 var cubeGeometry = new THREE.CubeGeometry(10,10,8); 
 var cubeMaterial = new THREE.MeshLambertMaterial({color:0x00ffff}); 
 
 var cube = new THREE.Mesh(cubeGeometry, cubeMaterial); 
 cube.position.x = 25; 
 cube.position.y = 5; 
 cube.position.z = -5; 
 
 //告诉立方体需要投射阴影 
 cube.castShadow = true; 
 
 scene.add(cube); 
 
 //底部平面 
 var planeGeometry = new THREE.PlaneGeometry(100,100); 
 var planeMaterial = new THREE.MeshStandardMaterial({color:0xaaaaaa}); 
 
 var plane = new THREE.Mesh(planeGeometry, planeMaterial); 
 plane.rotation.x = - 0.5 * Math.PI; 
 plane.position.y = -0; 
 
 //告诉底部平面需要接收阴影 
 plane.receiveShadow = true; 
 
 scene.add(plane); 
 
 } 
 
 //初始化性能插件 
 var stats; 
 function initStats() { 
 stats = new Stats(); 
 document.body.appendChild(stats.dom); 
 } 
 
 //用户交互插件 鼠标左键按住旋转,右键按住平移,滚轮缩放 
 var controls; 
 function initControls() { 
 controls = new THREE.TrackballControls( camera ); 
 //旋转速度 
 controls.rotateSpeed = 5; 
 //变焦速度 
 controls.zoomSpeed = 3; 
 //平移速度 
 controls.panSpeed = 0.8; 
 //是否不变焦 
 controls.noZoom = false; 
 //是否不平移 
 controls.noPan = false; 
 //是否开启移动惯性 
 controls.staticMoving = false; 
 //动态阻尼系数 就是灵敏度 
 controls.dynamicDampingFactor = 0.3; 
 //未知,占时先保留 
 //controls.keys = [ 65, 83, 68 ]; 
 controls.addEventListener( 'change', render ); 
 } 
 
 function render() { 
 renderer.render( scene, camera ); 
 } 
 
 //窗口变动触发的函数 
 function onWindowResize() { 
 
 camera.aspect = window.innerWidth / window.innerHeight; 
 camera.updateProjectionMatrix(); 
 controls.handleResize(); 
 render(); 
 renderer.setSize( window.innerWidth, window.innerHeight ); 
 
 } 
 
 function animate() { 
 //更新控制器 
 render(); 
 
 //更新性能插件 
 stats.update(); 
 
 controls.update(); 
 
 requestAnimationFrame(animate); 
 } 
 
 function draw() { 
 initRender(); 
 initScene(); 
 initCamera(); 
 initLight(); 
 initModel(); 
 initControls(); 
 initStats(); 
 
 animate(); 
 window.onresize = onWindowResize; 
 } 
</script> 
</html> 

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用Three.js具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。


# three.js  # 阴影  # 锯齿  # 效果  # JSP实现弹出登陆框以及阴影效果  # WebGL three.js学习笔记之阴影与实现物体的动画效果  # js当前页面登录注册框  # 固定div  # 底层阴影的实例代码 


相关文章: 如何选择高效响应式自助建站源码系统?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  如何在Windows环境下新建FTP站点并设置权限?  定制建站流程解析:需求评估与SEO优化功能开发指南  长沙企业网站制作哪家好,长沙水业集团官方网站?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何设置并定期更换建站之星安全管理员密码?  如何在阿里云服务器自主搭建网站?  建站之星后台管理如何实现高效配置?  南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?  如何通过VPS建站无需域名直接访问?  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  网站制作大概多少钱一个,做一个平台网站大概多少钱?  存储型VPS适合搭建中小型网站吗?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  C#如何使用XPathNavigator高效查询XML  制作网站的公司有哪些,做一个公司网站要多少钱?  焦点电影公司作品,电影焦点结局是什么?  如何制作一个表白网站视频,关于勇敢表白的小标题?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  建站为何优先选择香港服务器?  ,交易猫的商品怎么发布到网站上去?  ,柠檬视频怎样兑换vip?  哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何将凡科建站内容保存为本地文件?  历史网站制作软件,华为如何找回被删除的网站?  c++如何打印函数堆栈信息_c++ backtrace函数与符号名解析【方法】  定制建站价位费用解析与套餐推荐全攻略  如何快速搭建高效简练网站?  香港服务器建站指南:免备案优势与SEO优化技巧全解析  广东专业制作网站有哪些,广东省能源集团有限公司官网?  如何基于PHP生成高效IDC网络公司建站源码?  如何用IIS7快速搭建并优化网站站点?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  如何快速生成橙子建站落地页链接?  建站之星价格显示格式升级,你的预算足够吗?  威客平台建站流程解析:高效搭建教程与设计优化方案  如何在万网开始建站?分步指南解析  如何用好域名打造高点击率的自主建站?  如何选择服务器才能高效搭建专属网站?  学校为何禁止电信移动建设网站?  如何在Golang中指定模块版本_使用go.mod控制版本号  如何彻底卸载建站之星软件?  建站之星伪静态规则如何设置?  建站之星北京办公室:智能建站系统与小程序生成方案解析  jQuery 常见小例汇总  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  如何通过NAT技术实现内网高效建站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。