Three.js 必背核心方法

一、场景(容器,放所有东西)

js 复制代码
const scene = new THREE.Scene();

作用:3D 世界的容器,所有物体、灯光、相机都要放进去。

二、相机(观察者视角,2 种最常用)

1. 透视相机(人眼视角,最常用)

js 复制代码
const camera = new THREE.PerspectiveCamera(
    fov, // 视野角度(推荐 50~75)
    aspect, // 宽高比(画布宽/高)
    near, // 近裁剪面(≥0.1,太近会穿模)
    far // 远裁剪面(能看多远)
);

常用设置

js 复制代码
camera.position.set(x, y, z); // 相机位置
camera.lookAt(x, y, z); // 相机看向哪

2. 正交相机(2D视角,无近大远小)

js 复制代码
const camera = new THREE.OrthographicCamera( left, right, top, bottom, near, far );

三、渲染器(把画面画到屏幕)

js 复制代码
const renderer = new THREE.WebGLRenderer({
    antialias: true, // 抗锯齿(必开)
    alpha: true // 开启透明通道
});
renderer.setSize(width, height); // 设置画布大小
renderer.render(scene, camera); // 渲染画面(核心方法)

四、物体(网格 = 形状 + 材质)

1. 创建几何体(形状)

js 复制代码
const geometry = new THREE.BoxGeometry(宽, 高, 深); 

2. 创建材质(外观/颜色)

js 复制代码
// 基础材质(不受光影响)
const material = new THREE.MeshBasicMaterial({ color: 0xff0000 });

// 标准材质(受光影响,真实感) 
const material = new THREE.MeshStandardMaterial({ color: 0xff0000 }); 

3. 创建网格(最终物体)

js 复制代码
const mesh = new THREE.Mesh(geometry, material); 
scene.add(mesh); // 加入场景 

4. 物体常用属性

js 复制代码
mesh.position.set(x,y,z); // 位置 
mesh.rotation.set(x,y,z); // 旋转(弧度) 
mesh.scale.set(x,y,z); // 缩放 

五、光源(让物体有明暗)

1. 平行光(太阳,最常用)

js 复制代码
const light = new THREE.DirectionalLight(颜色, 强度); 
light.position.set(x,y,z); 
scene.add(light); 

2. 环境光(全局柔光,防止全黑)

js 复制代码
const ambient = new THREE.AmbientLight(颜色, 强度); 
scene.add(ambient); 

六、动画循环(动起来)

js 复制代码
function animate() { 
    requestAnimationFrame(animate); // 在这里写动画:旋转/移动物体 
    mesh.rotation.y += 0.01; 
    renderer.render(scene, camera); 
} 
animate(); 

七、辅助工具(调试神器)

1. 坐标轴辅助

js 复制代码
const axesHelper = new THREE.AxesHelper(长度); 
scene.add(axesHelper); 

2. 相机辅助

js 复制代码
const cameraHelper = new THREE.CameraHelper(camera); 
scene.add(cameraHelper); 
相关推荐
小小小小宇1 小时前
OpenMemory MCP
前端
和平宇宙2 小时前
AI笔记005. hermes-DeepSeek V4 Pro, 128K上下文引发的探索
前端·人工智能·笔记
IT_陈寒2 小时前
Redis持久化这个坑,我爬了一整天才出来
前端·人工智能·后端
naildingding2 小时前
3-ts接口 Interface
前端·typescript
小小前端仔LC3 小时前
Node.js + LangChain + React:搭建个人知识库(六)- “吃什么”项目实战:从700+菜谱入库到Taro H5端JSON渲染
前端·后端
晓13133 小时前
【Cocos Creator 3.x】篇——第二章 入门
前端·javascript·游戏引擎
程序员黑豆3 小时前
AI全栈开发之Java:怎么配置Java环境变量
前端·后端·ai编程
xiaofeichaichai3 小时前
React Hooks
前端·javascript·react.js
问心无愧05134 小时前
ctf show web入门110
前端·笔记
拉拉肥_King4 小时前
Vue 3 主题切换深度解析:从炫酷动画到零闪烁方案
前端·vue.js