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); 
相关推荐
wuhen_n2 小时前
Vue3 组件中的图片懒加载与渐进式加载
前端·javascript·vue.js
叫回忆2 小时前
elpis的npm抽离与发布
前端·javascript
wuhen_n2 小时前
Vite 构建层面的图片优化:从压缩到转换
前端·javascript·vue.js
hashiqimiya2 小时前
vue项目组装-路由-文件修改地方
前端·javascript·vue.js
Mike_jia2 小时前
ChatClaw:5 分钟打造你的个人 AI 智能体
前端
CodeSheep2 小时前
王自如公开招聘01号员工,这要求有多离谱?
前端·后端·程序员
亿元程序员2 小时前
“我要验牌”很火吗?我特意写了个Shader去验...
前端
@yanyu6662 小时前
04vue3基础
前端·javascript·vue.js
IT_陈寒2 小时前
JavaScript 闭包陷阱:90%开发者踩过的5个坑,你中招了吗?
前端·人工智能·后端