cesium相机(camera)控制

camera基础属性:

Cesium 中的相机通过 viewer.camera 来获取和操作。

position:相机的位置,用 Cartesian3 坐标表示,表示的是相机在世界坐标系中的绝对位置。

javascript 复制代码
viewer.camera.position = Cesium.Cartesian3.fromDegrees(longitude, latitude, height);

direction:相机的朝向,指向相机正在查看的目标。

javascript 复制代码
viewer.camera.direction = new Cesium.Cartesian3(x, y, z);

up:相机的上方向,用于定义相机的倾斜角度(与地面的垂直方向)

javascript 复制代码
viewer.camera.up = new Cesium.Cartesian3(x, y, z);

right:相机的右方向,定义相机横向的方向。

控制相机视角:

setView() 是 Cesium 中一个常用的方法,用于设置相机的视图,包括位置、目标点和相机的方向。

javascript 复制代码
viewer.camera.setView({
   // 相机的位置
  destination: Cesium.Cartesian3.fromDegrees(longitude, latitude, height),  
  // 相机方向
  orientation: {

// 水平旋转角度,从正北顺时针旋转到目标方向的角度
    heading: Cesium.Math.toRadians(heading),  
// 朝向的方位角,即相机绕着地心的水平方向旋转,范围: 0-2π
//0   - 正北
//π/2 - 正东
// π   - 正南
// 3π/2 - 正西


//直旋转角度,从水平面向上/向下的角度
    pitch: Cesium.Math.toRadians(pitch),      
// 俯仰角,即相机绕着横轴的上下旋转,范围: -π/2 到 π/2
// π/2   - 正上方(90°)
// 0     - 水平(0°)
// -π/2  - 正下方(-90°)

//相机自身的旋转角度
    roll: 0                                   
// 滚转角,即相机绕着前后轴的旋转,范围: -π 到 π
// 0     - 正常
// π     - 倒置
// π/2   - 右倾斜90°
// -π/2  - 左倾斜90°

  }
});

flyTo() 方法提供了平滑的动画过渡,来控制相机飞行到指定的位置。

javascript 复制代码
viewer.camera.flyTo({
  destination: Cesium.Cartesian3.fromDegrees(longitude, latitude, height),
  orientation: {
    heading: Cesium.Math.toRadians(heading),
    pitch: Cesium.Math.toRadians(pitch),
    roll: 0
  },
  duration: 3,  // 飞行持续时间,单位秒
  complete: function() {
    console.log("Fly complete!");
  }
});

lookAt()相机看向某个目标点

javascript 复制代码
var target = Cesium.Cartesian3.fromDegrees(120.0, 30.0);
viewer.camera.lookAt(target, new Cesium.Cartesian3(0.0, 0.0, 5000.0));  // 相机距离目标5000米

zoomTo是Cesium中用于控制相机视角和定位

javascript 复制代码
// viewer.zoomTo 实际上是对 camera.viewBoundingSphere 的封装
viewer.zoomTo(target, offset);  

// 等同于
viewer.camera.viewBoundingSphere(boundingSphere, offset);

// 应用
// 1. 飞向实体
viewer.zoomTo(entity);
// 2. 飞向实体集合
viewer.zoomTo(viewer.entities);

// 3. 飞向数据源
viewer.zoomTo(dataSource);

相机事件:

相机轨迹飞行:

Cesium 还可以让相机沿着一条预设的轨迹飞行,比如沿着多段 Cartesian3 位置点。可以使用 flyTo 配合 Polyline 来模拟轨迹飞行。

javascript 复制代码
var positions = [
  Cesium.Cartesian3.fromDegrees(120.0, 30.0, 5000),
  Cesium.Cartesian3.fromDegrees(121.0, 30.5, 5000),
  Cesium.Cartesian3.fromDegrees(122.0, 31.0, 5000)
];

viewer.camera.flyTo({
  destination: positions[0],
  complete: function() {
    viewer.camera.flyTo({
      destination: positions[1]
    });
  }
});

视觉化理解相机:

假设你是摄影师,相机属性就像这样:

  1. 你站在哪里? -> position
  2. 你看向哪里? -> direction
  3. 你的头顶朝向哪里? -> up
  4. 你的右手指向? - right
  5. 你水平转动脖子左右转头 -> heading
  6. 你点头或抬头 -> pitch
  7. 你歪着头 -> roll
相关推荐
周胡杰7 分钟前
鸿蒙文件上传-从前端到后端详解,对比jq请求和鸿蒙arkts请求区别,对比new FormData()和鸿蒙arktsrequest.uploadFile
前端·华为·harmonyos·鸿蒙·鸿蒙系统
2501_915373881 小时前
electron+vite+vue3 快速入门教程
前端·javascript·electron
硅谷秋水1 小时前
基于视觉的自动驾驶 3D 占据预测:回顾与展望
人工智能·机器学习·计算机视觉·3d·自动驾驶
zhl9999999991 小时前
xe-upload上传文件插件
前端·上传文件·xe-upload·兼容app上传文件
pixle01 小时前
Vue3 Echarts 3D立方体柱状图实现教程
3d·信息可视化·echarts
宁酱醇3 小时前
CSS基础_@拉钩教育【笔记】
前端·css
建群新人小猿3 小时前
CRMEB-PRO系统定时任务扩展开发指南
android·java·开发语言·前端
牧天白衣.3 小时前
vue 和 html 的区别
前端
知识分享小能手3 小时前
JavaScript学习教程,从入门到精通,Ajax数据交换格式与跨域处理(26)
xml·开发语言·前端·javascript·学习·ajax·css3
好名字08213 小时前
el-tabs与table样式冲突导致高度失效问题解决(vue2+elementui)
前端·vue.js·elementui