React+three.js之项目搭建

第一步:创建 React + TS 项目

javascript 复制代码
npm create vite@latest react-three-demo -- --template react-ts
cd react-three-demo
npm install

第二步:安装 three.js 和类型声明

javascript 复制代码
npm install three
npm install @types/three -D

第三步:新建 Three 组件 src/ThreeScene.tsx

three.js核心七步

  1. 创建场景(Scene) 2. 创建相机(Camera) 3. 创建渲染器(Renderer) 4. 创建物体(Geometry + Material + Mesh) 5. 添加物体到场景 6. 开启动画循环(animate) 7. 销毁清理(useEffect return)
javascript 复制代码
import { useRef, useEffect } from 'react';
import * as THREE from 'three';

const ThreeScene = () => {
  // 容器DOM
  const containerRef = useRef<HTMLDivElement>(null);

  useEffect(() => {
    if (!containerRef.current) return;

    // 1. 创建场景(放东西的地方)
    const scene = new THREE.Scene();

    // 2. 创建相机(眼睛)
    const width = containerRef.current.clientWidth;
    const height = containerRef.current.clientHeight;
    const camera = new THREE.PerspectiveCamera(75, width / height, 0.1, 1000);
    camera.position.z = 5; //退后五步才能看到物体

    // 3. 创建渲染器(画家)把3d场景画到网页上,会生成一个canvas标签
    const renderer = new THREE.WebGLRenderer({ antialias: true });
    renderer.setSize(width, height);
    renderer.setPixelRatio(window.devicePixelRatio);
    containerRef.current.appendChild(renderer.domElement);

    // 4. 创建物体(形状,皮肤)
    const geometry = new THREE.BoxGeometry(1, 1, 1);//形状
    const material = new THREE.MeshNormalMaterial();//材质
    const cube = new THREE.Mesh(geometry, material);//物体
    scene.add(cube);//把物体放进场景内

    // 5. 动画循环,让画面动起来
    let animateId: number;
    const animate = () => {
      animateId = requestAnimationFrame(animate);
      cube.rotation.x += 0.01;
      cube.rotation.y += 0.01;
      renderer.render(scene, camera);
    };
    animate();

    // 6. 窗口自适应
    const handleResize = () => {
      if (!containerRef.current) return;
      const w = containerRef.current.clientWidth;
      const h = containerRef.current.clientHeight;
      camera.aspect = w / h;
      camera.updateProjectionMatrix();
      renderer.setSize(w, h);
    };
    window.addEventListener('resize', handleResize);

    // 7. 组件销毁:释放内存、取消帧动画
    return () => {
      cancelAnimationFrame(animateId);
      window.removeEventListener('resize', handleResize);
      renderer.dispose();
      geometry.dispose();
    };
  }, []);

  return (
    <div 
      ref={containerRef} 
      style={{ width: '100vw', height: '100vh' }}
    />
  );
};

export default ThreeScene;
相关推荐
砍材农夫几秒前
物联网 基于netty核心实战-安全tls
java·开发语言·前端·物联网·安全
SEO_juper1 分钟前
JavaScript 渲染:AI 智能体无法读取,直接影响收录
开发语言·前端·javascript·aigc·seo·跨境电商·geo
whuhewei3 分钟前
一道React缓存的题目
javascript·react.js
i220818 Faiz Ul11 分钟前
在线预约导游|基于SSM+vue的在线预约导游系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·在线预约导游系统
ZC跨境爬虫12 分钟前
跟着 MDN 学CSS day_35:浮动布局完全指南
前端·css·ui·html·tensorflow
魔士于安16 分钟前
红色文化馆技术文档
前端·unity·游戏引擎·贴图·模型
何何____19 分钟前
js的数据存储机制
开发语言·前端·javascript·ecmascript
无风听海29 分钟前
构建现代 Web 应用的令牌安全体系:Refresh Token Rotation、HttpOnly Cookie 与 Grace Period 全解析
前端·安全
云水一下30 分钟前
JavaScript 从零基础到精通系列:对象、数组与 ES6 数据操作利器
前端·javascript
四代水门31 分钟前
服务端倒带(Server-Side Rewind)命中判定系统
java·前端·算法