当前位置: 首页 > news >正文

Cesium 问题:获取高度值,高度值又是相对于谁来说的

文章目录

    • 问题
    • 分析

问题

今天在开发中,甲方提出一个这样的问题,你的高度是怎么算出来的,对此,我只知道使用并不知道怎么来的,因此特意查了一番资料,希望帮助到大家

分析

  • 在 Cesium 中,我们可以使用 Cesium 中提供的方法获取地形高度值。使用 viewer.scene.pickPosition 方法来获取指定屏幕位置的地理坐标和高度信息。该方法接受一个屏幕坐标作为参数,并返回一个 Promise 对象,该对象将解析为包含地理坐标和高度信息的 Cartesian3 对象。

  • 以下是一个示例代码,演示如何使用 pickPosition 方法获取屏幕位置的高度值:

var viewer = new Cesium.Viewer('cesiumContainer');// 创建一个 ScreenSpaceEventHandler 对象来处理屏幕空间事件
var handler = new Cesium.ScreenSpaceEventHandler(viewer.scene.canvas);// 注册鼠标左击事件的处理函数
handler.setInputAction(function(movement) {// 获取鼠标点击位置的地理坐标和高度var pickedObject = viewer.scene.pickPosition(movement.position);// 判断是否拾取到了地理位置if (Cesium.defined(pickedObject)) {// 获取地理坐标和高度信息var position = pickedObject.position;var cartographicPosition = Cesium.Cartographic.fromCartesian(position);var height = cartographicPosition.height;console.log('点击位置的高度值为:', height);}
}, Cesium.ScreenSpaceEventType.LEFT_CLICK);
  • 在上述代码中,我们首先创建了一个 Viewer 对象并创建了一个 ScreenSpaceEventHandler 对象来处理屏幕空间事件。

  • 然后,我们注册了鼠标左击事件的处理函数。在处理函数中,我们使用 viewer.scene.pickPosition 方法来获取鼠标点击位置的地理坐标和高度信息。

  • 如果成功拾取到地理位置,我们将获取到的 Cartesian3 对象转换为 Cartographic 对象,并从中提取出高度值。

  • 最后,我们将高度值输出到控制台。

  • 请注意,使用 pickPosition 方法获取高度值需要进行地形数据的加载。如果未加载地形数据,将无法获得准确的高度值。你可以根据实际情况进行相应的地形数据加载配置。

那么,Cesium 中提供的方法获取地形高度值是怎么来的,相对于什么参考得出的值

  • 在 Cesium 中,获取地形高度值是通过地形数据进行计算得出的。Cesium使用了魔方(Cube)地形数据格式来表示地形。这个格式将地球表面划分为许多小的方块,每个方块包含一个高程值。当需要获取某个位置的高度值时,Cesium会根据该位置所在的方块以及邻近的方块,进行插值计算来估算高度值。

  • 具体来说,Cesium使用了地形切片(Terrain Tile)的概念。地形切片是一种预先生成的地形数据块,每个切片都包含了一定区域的地形高程数据。这些地形切片按照一定的层次结构组织起来,构成了整个地球的地形数据。

  • 当你使用 viewer.scene.pickPosition 方法获取地理位置的高度时,Cesium内部会找到包含该位置的最适合的地形切片,并从该切片中提取出相应的高度值。

  • 高度值是相对于基准椭球体(reference ellipsoid)计算得出的。椭球体是一个与地球形状相似的数学模型,它在地球表面处处与地球相切。Cesium使用国际椭球体(WGS84)作为基准椭球体。高度值表示的是地表相对于基准椭球体表面的垂直距离。

  • 需要注意的是,地形数据的精度和分辨率对高度的计算精度有影响。较高的地形数据分辨率可以提供更精确的高度值,但同时也需要更多的计算资源和加载时间。

http://www.lryc.cn/news/174565.html

相关文章:

  • 第三、四、五场面试
  • 力扣-290.单词规律
  • 常见限流算法学习
  • JS面试相关
  • SSRF漏洞
  • Qt5开发及实例V2.0-第十八章-Qt-MyselfQQ实例
  • 当下IT测试技术员的求职困境
  • MR混合现实情景实训教学
  • 嵌入式C++总结
  • C语言之内存函数篇(3)
  • java面试题-学成在线项目
  • ViewBinding——Android之视图绑定
  • vue学习-04vue的props配置项和mixin混入
  • 九、多项式朴素贝叶斯算法(Multinomial NB,Multinomial Naive Bayes)(有监督学习)
  • 数据结构上机练习——单链表的基本操作、头文件、类定义、main函数、多种链表算法的实现,含注释
  • 如何通过AI视频智能分析技术,构建着装规范检测/工装穿戴检测系统?
  • C语言自定义类型(上)
  • Python - 小玩意 - 圣诞树背景音乐弹窗
  • The 2023 ICPC Asia Regionals Online Contest (1) E. Magical Pair(数论 欧拉函数)
  • <十三>objectARX开发:模拟实现CAD的移动Move命令
  • Autosar基础:模式管理-EcuM
  • 代码随想录Day42 | 01背包问题| 416. 分割等和子集
  • UML六大关系总结
  • ElementUI基本介绍及登录注册案例演示
  • Python爬虫-某网酒店评论数据
  • C# Onnx Yolov8 Detect 水果识别
  • 测试网页调用本地可执行程序(续1:解析参数中的中文编码)
  • C++入门知识
  • spring和springmvc常用注解
  • 【Java】Java生成PDF工具类