【three.js系列三】入门教程——轨道控制器

什么是 OrbitControls 轨道控制

轨道控制器(OrbitControls)是 Three.js 中的一个常用工具,用于控制相机的运动。它可以使相机围绕目标物体进行旋转、缩放和平移操作,就像地球围绕太阳一样运动,方便观察三维场景。

使用轨道控制器

要使用轨道控制器,首先需要在项目中引入 OrbitControls.js 文件。然后,可以按照以下步骤创建并使用轨道控制器:

  1. 创建一个 OrbitControls 对象,并传入相机对象和渲染器对象。
  2. OrbitControls 对象添加到场景中。
  3. 监听 OrbitControls 对象的事件,以便在相机发生变化时更新场景。

以下代码基于vue项目,搭建vue项目,安装threejs即可

js 复制代码
// main.js
import * as THREE from "three";

// 引入轨道控制器扩展库OrbitControls.js(必须)
import { OrbitControls } from 'three/addons/controls/OrbitControls.js';

// 创建相机
const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
camera.position.set(0, 0, 5);

// 创建渲染器
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
document.body.appendChild(renderer.domElement);

// 创建场景
const scene = new THREE.Scene();

// 创建轨道控制器
// 2个参数:要控制的摄像机,用于事件侦听器的 HTML 元素
const controls = new OrbitControls(camera, renderer.domElement);

// 添加阻尼
controls.enableDamping = true
controls.dampingFactor = 0.01

// 自动旋转
controls.autoRotate = true
controls.autoRotateSpeed = 0.5

// 将轨道控制器添加到场景中
scene.add(controls);

// 创建一个立方体
const geometry = new THREE.BoxGeometry(1, 1, 1);
const material = new THREE.MeshBasicMaterial({ color: 0x0000ff });
const cube = new THREE.Mesh(geometry, material);
scene.add(cube);

// 添加网格
// 4个参数分别为:网格的大小(默认值为 `10`),网格中的分区数(默认值为 `10`),中心线的颜色(可选),网格线颜色(可选)
const gridHelper =new THREE.GridHelper(10,10, 0x00ff00, 'red')
scene.add(gridHelper)

// 监听相机变化事件
controls.addEventListener('change', () => {
  renderer.render(scene, camera);
});

// 动画循环
function animate() {
  requestAnimationFrame(animate);
  cube.rotation.x += 0.01;
  cube.rotation.y += 0.01;
  controls.update(); // 更新轨道控制器

  renderer.render(scene, camera);
}

animate();

打开浏览器:http://localhost:5173/

结语

对于添加几何体、相机、场景等不熟悉的童鞋可以参考上一篇 【three.js系列二】入门教程------几何体

相关推荐
Asort11 分钟前
JavaScript 从零开始(六):控制流语句详解——让代码拥有决策与重复能力
前端·javascript
无双_Joney30 分钟前
[更新迭代 - 1] Nestjs 在24年底更新了啥?(功能篇)
前端·后端·nestjs
在云端易逍遥32 分钟前
前端必学的 CSS Grid 布局体系
前端·css
ccnocare33 分钟前
选择文件夹路径
前端
艾小码33 分钟前
还在被超长列表卡到崩溃?3招搞定虚拟滚动,性能直接起飞!
前端·javascript·react.js
闰五月34 分钟前
JavaScript作用域与作用域链详解
前端·面试
泉城老铁38 分钟前
idea 优化卡顿
前端·后端·敏捷开发
前端康师傅38 分钟前
JavaScript 作用域常见问题及解决方案
前端·javascript
司宸39 分钟前
Prompt结构化输出:从入门到精通的系统指南
前端