通过three.js玩转车展项目

1.项目搭建

1.1 创建文件夹

javascript 复制代码
mkdir 文件名

1.2 初始化package.json

javascript 复制代码
npm init -y

1.3 安装打包工具并配置相关依赖

javascript 复制代码
npm i parcel -d

在package.json中打包路径和指令

1.4 安装three.js

复制代码
npm i three -d

2.项目搭建

2.1 新建index.html,并再index.html引入car.js,在car.js开始初始化

2.2 在car.js中初始化场景、相机、渲染器器、以及轨道控制器,此时在运行效果如下:

具体实现:

2.3 初始化载入汽车模型和初始化灯光,在init里面调用即可

运行效果如下:

2.4 建立多个光带来回移动,并照亮汽车

运行效果如下:

2.5 监听视口变化,视口变化时,及时更新相机的宽高比和渲染器的尺寸

2.6 初始化地板

运行效果如下:

2.7 初始化四周墙壁,来使得场景更加真实

运行效果如下:

2.9 初始化车身、玻璃的基础材质,通过遍历车的模型节点,区分出什么是车身、玻璃和车门,通过GUI图形用户界面可分别实现车身颜色、玻璃颜色的替换、以及车门开关和车内外视角的转变。



运行效果如下:

2.10 聚光灯初始化,使场景更加真实

运行效果如下:

2.11 监听点击事件,判断光线穿过了什么物体,从而实现开关车门的交互

运行效果如下:

3. 项目源码地址:

点击跳转源码

相关推荐
ZC跨境爬虫40 分钟前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。2 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星2 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒2 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩2 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi2 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
哆来A梦没有口袋2 小时前
干货精讲 | 初级CSS面试高频考题
前端·css·面试
掘金013 小时前
EmbedPDF Vue 版 完整正文文档 全网首发
前端
OpenTiny社区3 小时前
操作ArkTS页面跳转及路由相关心得
前端·typescript·web·opentiny
xiaohua0708day3 小时前
Lodash库
前端·javascript·vue.js