前言

众所周知作为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小时内与您取得联系。