当前位置: 首页 > news >正文

Three.js + React 实战系列 - 项目展示区开发详解 Projects 组件(3D 模型 + 动效 + 状态切换)✨

对个人主页设计和实现感兴趣的朋友可以订阅我的专栏哦!!谢谢大家!!!

在这一篇博客中,我们将搭建项目主页中极具互动性的 Projects 区域。

该组件承担着展示个人项目展示的功能,融合 GSAP 动画、@react-three/fiber 3D 展示与交互式切换等高级特性,用户体验上极具冲击力。

React + ThreeJS 个人主页小项目:🎥 05 · 项目展示区开发详解 Projects 组件(3D 模型 + 动效 + 状态切换)

✨ 组件亮点概览

  • 结合 GSAP 实现文字动画过渡效果;
  • 通过 <Canvas> 实现 3D 电脑模型展示;
  • 支持左右翻页浏览多个项目;
  • 响应式设计与美观的卡片式信息布局。

## 📁 项目结构建议

组件路径:

src/
├— components/
│   └— DemoComputer.jsx
├— sections/
│   └— Projects.jsx
└— constants/├— index.js

🔄 状态切换逻辑

我们定义了 selectedProjectIndex 来记录当前浏览的项目,通过 handleNavigation 来控制前后切换逻辑,形成一个循环浏览:

const handleNavigation = (direction) => {setSelectedProjectIndex((prevIndex) => {if (direction === 'previous') {return prevIndex === 0 ? projectCount - 1 : prevIndex - 1;} else {return prevIndex === projectCount - 1 ? 0 : prevIndex + 1;}});
};

🌟 动画效果(GSAP)

通过 useGSAP,我们对每次切换项目时的 .animatedText 类名文字应用淡入动画,增强用户体验:

useGSAP(() => {gsap.fromTo('.animatedText', { opacity: 0 }, {opacity: 1,duration: 1,stagger: 0.2,ease: 'power2.inOut'});
}, [selectedProjectIndex]);

fromTo 方法:初始状态将文字透明度设为 0,然后在 1 秒内逐个淡入(通过 stagger 实现),动画曲线为 power2.inOut,使文字的出现显得柔和流畅,极大提升了用户在浏览项目时的沉浸感和专业感。


🖼️ 左侧:项目信息面板

包括:项目封面图、logo、标题描述、标签、跳转链接,以及左右切换按钮。

<img src={currentProject.spotlight} alt="spotlight" className="..." />
<p className="text-white text-2xl font-semibold animatedText">{currentProject.title}</p>

所有数据来源于 myProjects 常量数组,并支持动态渲染每个项目对应的内容。


🖥️ 右侧:3D 电脑展示区域

采用 @react-three/fiber<Canvas> 实现沉浸式项目封面展示。

<Canvas><ambientLight intensity={Math.PI} /><directionalLight position={[10, 10, 5]} /><Center><Suspense fallback={<CanvasLoader />}><group scale={2} position={[0, -3, 0]} rotation={[0, -0.1, 0]}><DemoComputer texture={currentProject.texture} /></group></Suspense></Center><OrbitControls maxPolarAngle={Math.PI / 2} enableZoom={false} />
</Canvas>

其中 DemoComputer 是一个自定义 3D 模型组件,配合不同 texture 显示不同项目封面。

在这里插入图片描述


📌 总结

Projects.jsx 组件是整个主页中前后端交互最强、技术栈最丰富的板块之一,建议优先理清以下要点:

  • 熟练使用 state 管理当前展示内容;
  • 理解如何配合 GSAP 动画提升 UX;
  • 熟悉 Fiber Canvas 与 Drei 工具的用法;
  • 数据抽象与复用能力的提升。

🔠 下一篇预告:客户评价区域

我们将在下一节中:

  • 🌟 构建客户评价区域(Client)
  • ✨ 使用 gsap 为内容添加滑入动效
  • ⛳️ 信息条目数据化驱动,方便扩展

对个人主页设计和实现感兴趣的朋友可以订阅我的专栏哦!!谢谢大家!!!
我们下一节见!👋

相关文章:

  • DeepSeek技术发展详细时间轴与技术核心解析
  • 【KWDB 创作者计划】基于 ESP32 + KWDB 的智能环境监测系统实战
  • 人工智能浪潮中Python的核心作用与重要地位
  • DeepSeek成本控制的三重奏
  • 学习路线(工业自动化软件架构)
  • 【将你的IDAPython插件迁移到IDA 9.x:核心API变更与升级指南】
  • suna工具调用可视化界面实现原理分析(一)
  • 2025系统架构师---论面向对象的软件设计
  • S100平台调试RS485/RS232
  • JavaSE笔记--反射篇
  • 位运算-详细总结
  • 前端-Vue的项目流程
  • 【Unity】一个AssetBundle热更新的使用小例子
  • 2023年408真题及答案
  • transformer读后感
  • QT6 源(77):阅读与注释滚动条 QScrollBar 的源码,其是基类QAbstractSlider 的子类,
  • 数据库原理——E-R图的极速省流理解 例题解析
  • 如何限制pod 进程/线程数量?
  • Python基本环境搭配
  • C++ 的动态多态
  • 一季度全国30强城市出炉:谁能更进一步?谁掉队了?
  • 五一假期上海接待游客1650万人次,全要素旅游交易总额超200亿元
  • 国铁集团:5月4日全国铁路预计发送旅客2040万人次
  • 旧宫新语|瑞琦:再探《古玩图》——清宫艺术品的前世与今生
  • 国羽3比0横扫日本晋级苏迪曼杯决赛,将战韩国与印尼胜者
  • 单阶段遭遇零封偶像奥沙利文,赵心童要让丁俊晖预言成真