相机动画总结-相机直线运动动画、相机圆周运动动画

相机动画总结(.position 和 .lookAt())

核心概念

相机动画主要通过控制相机对象的 .position 属性和 .lookAt() 方法来实现:

1. .lookAt() 方法

  • 功能:设置相机观察的焦点,相当于调整相机镜头的指向
  • 参数 :可以接受三个坐标参数 (x, y, z) 或一个 THREE.Vector3 向量
  • 重要特性
    • 执行 lookAt() 会更新视图矩阵的旋转部分
    • 执行前需要先设置相机位置 .position
    • 改变 .position 后如果不重新调用 lookAt(),相机的视线方向不会自动更新
  • 使用时机:当需要改变相机观察方向时调用

2. .position 属性

  • 功能:设置相机在世界坐标系中的位置
  • 重要特性
    • 仅改变 .position 只会更新视图矩阵的平移部分
    • 相机移动但镜头指向不变(像人走路不转头)
    • lookAt() 配合使用才能实现完整的视角控制

两种相机动画实现方式

1. 相机直线运动动画

javascript 复制代码
function render() {
  camera.position.x += 1;  // 沿X轴直线移动
  camera.lookAt(scene.position);  // 保持看向场景中心
  renderer.render(scene, camera);
  requestAnimationFrame(render);
}

特点

  • 相机沿固定方向移动
  • 需要调用 lookAt() 来保持观察方向
  • 效果类似人走路且转头看向固定目标

2. 相机圆周运动动画

javascript 复制代码
let angle = 0;
function render() {
  angle += 0.01;
  // 圆周运动公式
  camera.position.x = 半径 * Math.sin(angle);
  camera.position.z = 半径 * Math.cos(angle);
  camera.lookAt(scene.position);  // 始终看向圆心
  renderer.render(scene, camera);
  requestAnimationFrame(render);
}

特点

  • 相机围绕某个中心点做圆周运动
  • 必须每帧调用 lookAt() 来保持看向圆心
  • 会产生场景旋转的视觉效果(实际上是相机在绕场景旋转)

关键要点

  1. 协同工作.position.lookAt() 必须配合使用才能实现理想的相机动画效果
  2. 执行顺序 :先设置 .position,再调用 .lookAt()
  3. 更新频率:只要相机位置或方向发生变化,就需要在动画循环中更新这两个属性
  4. 视觉效果
    • 仅改变 .position = 相机移动,镜头方向不变
    • 仅调用 .lookAt() = 相机原地旋转镜头
    • 两者结合 = 相机边移动边调整观察方向

类比理解

可以把相机想象成一个人:

  • .position = 人的位置(走到哪里)
  • .lookAt() = 人的视线方向(看向哪里)
  • 直线运动 = 人沿着直线走,眼睛看向固定目标
  • 圆周运动 = 人绕着一个点转圈,眼睛一直盯着中心点

这种相机动画的实现方式是Three.js中实现场景漫游、视角变换等效果的基础。

相关推荐
JieE2124 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
candyTong7 小时前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
_柳青杨11 小时前
深入理解 JavaScript 事件循环
前端·javascript
大家的林语冰17 小时前
ES5 凉凉,Babel 8 正式发布,默认不再编译为 ES5 和 CJS......
前端·javascript·前端工程化
weedsfly19 小时前
异步编程全景与事件循环——彻底搞懂 JS 执行机制
前端·javascript
用户17335980753719 小时前
纯前端 PDF 数字签名实战:Vue 3 + pdf-lib 在浏览器里完成签名嵌入
前端·javascript
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
kyriewen1 天前
我用 AI 一周写完了整个项目,上线第一天就崩了——这是我踩过最贵的 5 个坑
前端·javascript·ai编程
Larcher1 天前
AI Loop:让AI像人一样自主完成任务的核心机制
javascript·人工智能·设计模式