【Cesium】Cesium实现淹没分析(CallbackProperty方式)

2023-11-11 05:40

本文主要是介绍【Cesium】Cesium实现淹没分析(CallbackProperty方式),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、淹没分析简介

淹没分析是指根据某区域的地形以及洪水流量速度,动态模拟该地形区域水位上涨过程。**该功能适用于地形起伏较大的区域。**目前Cesium实现淹没分析功能主要利用polygon的extruedHeight属性,在地形区域拾取几个点划定洪水淹没区,并规定洪水上涨限定高度,洪水从划定区域的最低处以polygon的方式逐渐上涨,达到限定高度后停止上涨,淹没过程结束。

二、淹没分析实现

2.1 淹没核心代码

//淹没分析
function floodAnalysis(positions,targertWaterHeight,waterHeight){console.log(targertWaterHeight);console.log(waterHeight);viewer.entities.add({polygon: {hierarchy: new Cesium.PolygonHierarchy(positions),extrudedHeight: new Cesium.CallbackProperty(function(){waterHeight += 0.5;if (waterHeight > targertWaterHeight) {waterHeight = targertWaterHeight;}return waterHeight;}, false),material: new Cesium.Color.fromBytes(64, 157, 253, 150),perPositionHeight: true,}})
}

其中positions为限定区域端点坐标数组,targetWaterHeight为洪水上涨限定高度,waterHeight为洪水起始高度。这里通过CallbackProperty来动态拉伸polygon。CallbackProperty是一个值,其值通过回调函数来决定,从它被创建开始,它就会不断地调用回调函数。

2.2 获取范围内地形高程极值

        由于不确定地形高程的最低点,若extruedHeight从0开始增加,则很可能从地底处开始上涨(因为地形高度一般大于0),所以要确定范围地形的最低点,才能很好的实现淹没分析效果
        目前Cesium没有提供相关方法来获取范围地形的高度极值,参考
Cesium获取绘制范围内地形高程进行淹没分析
这篇文章提供的思路,先构建范围地形的外接矩形,再构建矩形范围的格网,获取每个格网点处的高程,即可粗略计算洪水范围内地形的极值(采用了第三方库turf.js来构建网格):

//创建polygon外接矩形,并生成点格网,返回所有格网点坐标
function buildPolygonGrid(positions){const tempPoints = []for (let i = 0; i < positions.length; i++) {cid;var cartographic = ellipsoid.cartesianToCartographic(positions[i]);var lat = Cesium.Math.toDegrees(cartographic.latitude);var lng = Cesium.Math.toDegrees(cartographic.longitude);tempPoints.push([lng, lat]);}//生成外接矩形var line = turf.lineString(tempPoints);var bbox = turf.bbox(line);var bboxPolygon = turf.bboxPolygon(bbox);var area = turf.area(bboxPolygon);//生成格网//计算网格点之间的距离,尽量保证范围内有1万个左右格网点。var cellSide = Math.sqrt(area/1000000)/100;var options = { units: 'kilometers'};var grid = turf.pointGrid(bbox, cellSide, options);const gridPositions = [];grid.features.forEach(f => {gridPositions .push(Cesium.Cartographic.fromDegrees(f.geometry.coordinates[0], f.geometry.coordinates[1]));})const promise = Cesium.sampleTerrainMostDetailed(terrain, gridPositions);let maxHeight = 0;let minHeight = 10000.0;Promise.resolve(promise).then(function(updatedPositions) {for(let i=0;i<updatedPositions.length;i++){let height = updatedPositions[i].height;//获取格网点处地形高度minHeight = height < minHeight ? height:minHeight;maxHeight = height > maxHeight ? height:maxHeight;}document.getElementById("maxHeight").value = maxHeight;document.getElementById("minHeight").value = minHeight;});     
}

最终效果如下:在这里插入图片描述

这篇关于【Cesium】Cesium实现淹没分析(CallbackProperty方式)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/387926

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景