【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

相关文章

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Spring Boot读取配置文件的五种方式小结

《SpringBoot读取配置文件的五种方式小结》SpringBoot提供了灵活多样的方式来读取配置文件,这篇文章为大家介绍了5种常见的读取方式,文中的示例代码简洁易懂,大家可以根据自己的需要进... 目录1. 配置文件位置与加载顺序2. 读取配置文件的方式汇总方式一:使用 @Value 注解读取配置方式二

JAVA保证HashMap线程安全的几种方式

《JAVA保证HashMap线程安全的几种方式》HashMap是线程不安全的,这意味着如果多个线程并发地访问和修改同一个HashMap实例,可能会导致数据不一致和其他线程安全问题,本文主要介绍了JAV... 目录1. 使用 Collections.synchronizedMap2. 使用 Concurren

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py