ThreeJS创建一个3D物体的基本流程

**1.创建场景:**创建一个THREE.Scene实例,它将作为所有3D对象的容器。

javascript 复制代码
// 创建场景
const scene = new THREE.Scene();

**2.创建相机:**创建一个相机对象,通常是THREE.PerspectiveCamera,用于定义观察场景的视角和位置。

javascript 复制代码
//创建相机
const camera = new THREE.PerspectiveCamera(
  45, // 视角
  window.innerWidth / window.innerHeight, // 宽高比
  0.1, // 近平面
  1000 // 远平面
)

**3.设置相机位置 :**通过camera.position.set()设置相机坐标

javascript 复制代码
// 设置相机位置
camera.position.set(0, 0, 5);

**4.创建渲染器:**创建一个THREE.WebGLRenderer实例来渲染场景。

javascript 复制代码
// 创建渲染器
const renderer = new THREE.WebGLRenderer();

**5.设置渲染器尺寸:**使用renderer.setSize(width, height)根据需要设置渲染器的宽度和高度。

javascript 复制代码
renderer.setSize(window.innerWidth, window.innerHeight);

**6.添加渲染器的DOM元素到页面:**使用document.body.appendChild(renderer.domElement)将渲染器的DOM元素添加到HTML页面中。

javascript 复制代码
document.body.appendChild(renderer.domElement);

**7.创建几何体:**使用THREE.Geometry类或其子类来创建物体的几何形状。

javascript 复制代码
// 创建几何体
const geometry = new THREE.BoxGeometry(1, 1, 1);

**8.创建材质:**创建一个THREE.Material实例来定义物体的外观,包括颜色、纹理等。

javascript 复制代码
// 创建材质
const material = new THREE.MeshBasicMaterial({ color: 0x00ff00 });

**9.创建网格:**将几何体和材质结合起来创建一个实例,这是一个实际的3D物体。

javascript 复制代码
// 创建网格
const cube = new THREE.Mesh(geometry, material);

**10.添加物体到场景:**使用scene.add(cube)将创建的网格添加到场景中。

javascript 复制代码
// 将网格添加到场景中
scene.add(cube);

**11.渲染场景:**使用renderer.render(scene, camera)来渲染场景和相机。

javascript 复制代码
// 渲染到页面上
renderer.render(scene, camera);

**12.添加动画(可选):**如果需要,可以通过修改物体的位置、旋转或缩放属性,并在每次动画帧中重新渲染来创建动画效果。

javascript 复制代码
// 渲染函数
function animate() {
  requestAnimationFrame(animate);
  // 旋转
  cube.rotation.x += 0.01;
  cube.rotation.y += 0.01;
  // 渲染到页面上
  renderer.render(scene, camera);
}
animate();
相关推荐
AI_RSER5 小时前
第一篇:【Python-geemap教程(三)上】3D地形渲染与Landsat NDVI计算
开发语言·python·3d·信息可视化·遥感·gee
-dzk-5 小时前
【论文精读】3D Gaussian Splatting for Real-Time Radiance Field Rendering
数码相机·opencv·计算机视觉·3d·三维重建·3dgs·高斯
VSORender_Farm5 小时前
3ds Max:建筑效果图制作的核心利器与全流程解析
3d·渲染·云渲染·设计·建筑·效果图
格调UI成品14 小时前
[特殊字符] 数据可视化结合 three.js:让 3D 呈现更精准,3 个优化经验谈
javascript·3d·信息可视化
The moon forgets15 小时前
ALOcc: Adaptive Lifting-based 3D Semantic Occupancy and
深度学习·3d
Mintopia18 小时前
🧠 从像素到现实:用 Three.js + Cesium 构建数字孪生系统
前端·javascript·three.js
Mintopia1 天前
🧱 用三维点亮前端宇宙:构建你自己的 Three.js 组件库
前端·javascript·three.js
向宇it2 天前
【unity小技巧】封装unity适合2D3D进行鼠标射线检测,获取鼠标位置信息检测工具类
游戏·3d·unity·游戏引擎
中科米堆2 天前
中科米堆CASAIM金属件自动3d测量外观尺寸三维检测解决方案
人工智能·3d·视觉检测
山楂树の2 天前
模型优化——在MacOS 上使用 Python 脚本批量大幅度精简 GLB 模型(通过 Blender 处理)
python·macos·3d·图形渲染·blender