【无标题】

这段代码定义了一个用于 Cesium 地图的工具函数 getPosition,作用是获取指定三维 Cartesian3 坐标对应的经纬度、经度、最高高程(结合地形 / 模型高程和原始海拔)。以下是详细解析:

函数作用

根据输入的三维空间坐标(Cartesian3),计算该点的经纬度,并取地形 / 模型的实际高程原始海拔中的最大值,最终返回包含经纬度、最高高程的结果。

逐行解析

1. 函数定义
复制代码
export function getPosition(this: Cesium.Viewer, c3: Cesium.Cartesian3): { longitude: number, latitude: number, altitude: number, height: number }
  • this: Cesium.Viewer:指定函数的 this 上下文为 Cesium viewer 实例(地图视图对象)。
  • c3: Cesium.Cartesian3:输入参数,三维空间坐标(Cesium 中表示位置的常用类型)。
  • 返回值:包含经纬度(longitude/latitude)、最高高程(altitude)、预留字段(height)的对象。
2. 将三维坐标转换为地理坐标(弧度)
复制代码
const cartographic = this.scene.globe.ellipsoid.cartesianToCartographic(c3)
  • cartesianToCartographic:将 Cartesian3 三维坐标转换为 Cartographic 地理坐标(包含经度、纬度、海拔,单位为弧度和米)。
  • this.scene.globe.ellipsoid:地球椭球体对象(用于坐标转换的基准)。
3. 将弧度转换为度(经纬度)
复制代码
const longitude = Cesium.Math.toDegrees(cartographic.longitude)
const latitude = Cesium.Math.toDegrees(cartographic.latitude)
  • Cesium.Math.toDegrees:将弧度转换为度(经纬度通常以度为单位展示)。
  • longitude/latitude:最终的经度和纬度(度)。
4. 计算世界坐标与屏幕坐标
复制代码
const worldPosition = Cesium.Cartesian3.fromDegrees(longitude, latitude, cartographic.height);
const screenPosition = Cesium.SceneTransforms.wgs84ToWindowCoordinates(this.scene, worldPosition);
  • fromDegrees:将经纬度和海拔转换回世界坐标(Cartesian3),确保坐标基于原始海拔。
  • wgs84ToWindowCoordinates:将世界坐标转换为屏幕坐标(像素位置),用于后续拾取模型 / 地形表面。
5. 处理屏幕坐标无效的情况
复制代码
if (!screenPosition) {
  return { longitude, latitude, altitude: cartographic.height, height: 0 }
}
  • 如果屏幕坐标获取失败(如点在视野外),直接返回原始海拔作为高程。
6. 拾取模型 / 地形表面的实际高程
复制代码
const modelSurfacePosition = this.scene.pickPosition(screenPosition);
  • pickPosition:根据屏幕坐标拾取场景中模型或地形表面的三维坐标(考虑实际模型高度或地形起伏)。
7. 计算最高高程并返回结果
复制代码
if (modelSurfacePosition) {
  const modelposition = Cesium.Cartographic.fromCartesian(modelSurfacePosition);
  const height = modelposition.height; // 模型/地形表面的实际高程
  return { longitude, latitude, altitude: Math.max(cartographic.height, height), height: 0 }
} else {
  return { longitude, latitude, altitude: cartographic.height, height: 0 }
}
  • 若拾取到模型 / 地形表面坐标,将其转换为地理坐标并提取高程(height)。
  • Math.max(cartographic.height, height):取原始海拔与模型 / 地形高程中的最大值作为最终高程(altitude)。
  • 若未拾取到表面坐标,返回原始海拔。

核心逻辑总结

该函数的核心是融合 "原始坐标海拔" 和 "模型 / 地形实际高程",确保获取的高程是该点的最高值(例如:当点位于建筑物上方时,取建筑物顶部高程而非地面海拔)。

适用场景:需要精确获取地表或模型表面高程的交互(如点击拾取、坐标标注等)。

注意事项

  • pickPosition 依赖场景中的模型或地形数据,若场景中无模型且未加载地形,可能返回 undefined,此时会默认使用原始海拔。

  • 返回值中的 height 字段当前固定为 0,可能是预留用于扩展(如存储相对高度等)。

    export function getPosition(this: Cesium.Viewer, c3: Cesium.Cartesian3): { longitude: number, latitude: number, altitude: number, height: number } {
    const cartographic = this.scene.globe.ellipsoid.cartesianToCartographic(c3)
    const longitude = Cesium.Math.toDegrees(cartographic.longitude)
    const latitude = Cesium.Math.toDegrees(cartographic.latitude)

    复制代码
    const worldPosition = Cesium.Cartesian3.fromDegrees(longitude, latitude, cartographic.height);
    const screenPosition = Cesium.SceneTransforms.wgs84ToWindowCoordinates(
      this.scene,
      worldPosition
    );
    // console.log(longitude, latitude, '海拔', cartographic.height);
    if (!screenPosition) {
      return { longitude, latitude, altitude: cartographic.height, height: 0 }
    }
    const modelSurfacePosition = this.scene.pickPosition(screenPosition);
    if (modelSurfacePosition) {
      const modelposition = Cesium.Cartographic.fromCartesian(modelSurfacePosition);
      const height = modelposition.height;
      return { longitude, latitude, altitude: Math.max(cartographic.height, height), height: 0 }
    } else {
      return { longitude, latitude, altitude: cartographic.height, height: 0 }
    }

    }

获取坐标在地图中所有物体的做高点。可以获取3dtiles模型含高程数据的模型

相关推荐
努力努力再努力wz2 分钟前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!(附B树实现源码)
java·linux·开发语言·数据结构·c++·b树·算法
Sestid2 分钟前
前端AI编程使用技巧(后续会更新cursor和claude code for vscode)
前端·vscode·ai编程·claude·cursor
freeWayWalker5 分钟前
Vue通用缩放容器
前端·javascript·vue.js
王家视频教程图书馆9 分钟前
rust 写gui 程序 最流行的是哪个
开发语言·后端·rust
Wadli12 分钟前
Oncall Agent项目
开发语言
Hello--_--World13 分钟前
VUE:逻辑复用
前端·javascript·vue.js
艾莉丝努力练剑17 分钟前
【QT】Qt常用控件与布局管理深度解析:从原理到实践的架构思考
linux·运维·服务器·开发语言·网络·qt·架构
杜子不疼.18 分钟前
用 Python 实现 RAG:从文档加载到语义检索全流程
开发语言·人工智能·python
chao18984419 分钟前
基于改进二进制粒子群算法的含需求响应机组组合问题MATLAB实现
开发语言·算法·matlab