通过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. 项目源码地址:

点击跳转源码

相关推荐
程序员鱼皮5 小时前
我花 300 块,让 Claude Fable 5 开发桌面 APP,值么?
前端
William_Xu5 小时前
JavaScript 并发控制
前端
拾年2755 小时前
从零手写 Ajax:用原生 XHR 搭建前后端交互全流程
前端·javascript·ajax
光影少年5 小时前
懒加载与分包:React.lazy + Suspense
前端·react.js·掘金·金石计划
拉勾科研工作室6 小时前
区块链工程毕业论文题目【249个】
开发语言·javascript
小林ixn6 小时前
你以为你懂 + 号?看完这篇 Bun + TS 实战,才发现以前全写错了
前端·javascript·typescript
namexingyun6 小时前
开源前端生态如何成为 AI UI 生成的“燃料“:shadcn/ui、Tailwind CSS、Storybook 技术价值全解剖
java·前端·人工智能·python·ui·开源·ai编程
Zyed6 小时前
[STM32]Day15读写FLASH+读取ID
前端·stm32·性能优化
jvxiao7 小时前
你真的懂作用域吗?从编译原理角度深度 JS 的作用域
前端·javascript
Darling噜啦啦7 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构