热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SuperMap体元栅格数据在webgl中的运用

SuperMap体元栅格数据在webgl中的运用前言一、数据制作1.制作三维点数据集2.通过三维点数据集构建体元栅格3、体元栅格生成缓存4.将场景其他图层生成缓存,一

SuperMap体元栅格数据在webgl中的运用

    • 前言
    • 一、数据制作
    • 1.制作三维点数据集
    • 2.通过三维点数据集构建体元栅格
    • 3、体元栅格生成缓存
    • 4.将场景其他图层生成缓存,一并发布为三维服务
    • 二、在 SuperMap iClient3D for WebGL 上加载缓存数据,并调整效果
    • 以下为效果展示


前言

先前有一篇文章介绍了体元栅格数据的制作以及在iDesktop和webgl中叠加到模型上的效果展示(原文地址),今天我来介绍一下体元栅格数据如何在webgl中展示立体效果并实现各个方向剖切。

本文以日照率为例,从数据的制作到显示效果的调节整个流程进行说明。整个流程主要
分为以下五个部分:
1.通过 SuperMap iDesktop 生成原始三维点数据集;
2.根据三维点数据集构建体元栅格;
3.体元栅格数据生成缓存;
4.通过 SuperMap iServer 发布三维服务;
5.在 SuperMap iClient3D for WebGL 上加载缓存数据,并调整效果。

一、数据制作


1.制作三维点数据集

绘制三维面作为日照分析范围,通过导入面的方式生成日照分析
在这里插入图片描述
保存分析结果为三维点数据集
在这里插入图片描述

2.通过三维点数据集构建体元栅格

在这里插入图片描述

3、体元栅格生成缓存

右键体元栅格数据集生成缓存,弹出以下对话框(注意,该功能要求iDesktop版本为10i及以上)
在这里插入图片描述
生成成功以后,将缓存添加到场景,效果如下图所示
在这里插入图片描述

4.将场景其他图层生成缓存,一并发布为三维服务


二、在 SuperMap iClient3D for WebGL 上加载缓存数据,并调整效果

在 SuperMap iClient3D for WebGL 上打开场景,找到体元栅格缓存所在图层
(VoxelGridCache8),并设置缓存的显示效果:
1.通过 Gridlayer.style3D.fillForeColor = new Cesium.Color(1, 1, 1, 0.5)设置α小于 1,得到半透明效果。
需要注意的是,eyeDomeLighting 与半透明的效果互斥,因此需要将其设置为 false。
2.目前是以点云的方式来加载体元栅格缓存数据的,如果 pointSize 的值比较小,就会显示成很多稀疏的点,通过增加 pointSize 的值可以达到连续渐变的显示效果。具体 pointSize 的值可以参考构建体元栅格时设置的采样距离。本案例中,体元栅格采样距离为 4m 左右,pointSize设置为 7 效果较好

var Gridlayer = viewer.scene.layers.find('VoxelGridCache8');Gridlayer.style3D.fillForeColor = new Cesium.Color(1, 1, 1, 0.5);Gridlayer.lodRangeScale = 10;var hyp = new Cesium.HypsometricSetting();//设置半透明填充效果Gridlayer.style3D.fillForeColor = new Cesium.Color(1, 1, 1, 0.5);//设置点大小Gridlayer.style3D.pointSize = 7;Gridlayer.pointCloudShading.renderMode = 1;Gridlayer.pointCloudShading.eyeDomeLighting = false;setHypsometric(hyp, Gridlayer);function setHypsometric(hyp, layer) {var minValue = layer.dataMinValue;var maxValue = layer.dataMaxValue;hyp.DisplayMode = Cesium.HypsometricSettingEnum.DisplayMode.FACE;hyp.lineColor = new Cesium.Color(1.0, 1.0, 1.0, 1.0);hyp.LineInterval = 10.0;hyp.MaxVisibleValue = layer.dataMaxValue;hyp.MinVisibleValue = layer.dataMinValue;hyp.ColorTableMinKey = minValue;hyp.ColorTableMaxKey = maxValue;hyp.Opacity = 1;var colorTable = new Cesium.ColorTable();colorTable.insert(0.0, new Cesium.Color(201 / 255, 23 / 255, 30 / 255));colorTable.insert(0.1, new Cesium.Color(231 / 255, 50 / 255, 15 / 255));colorTable.insert(0.2, new Cesium.Color(238 / 255, 118 / 255, 0 / 255));colorTable.insert(0.3, new Cesium.Color(255 / 255, 214 / 255, 0 / 255));colorTable.insert(0.4, new Cesium.Color(246 / 255, 236 / 255, 0 / 255));colorTable.insert(0.5, new Cesium.Color(157 / 255, 200 / 255, 22 / 255));colorTable.insert(0.7, new Cesium.Color(104 / 255, 185 / 255, 61 / 255));colorTable.insert(0.9, new Cesium.Color(18 / 255, 110 / 255, 183 / 255));colorTable.insert(1.0, new Cesium.Color(0 / 255, 64 / 255, 152 / 255));hyp.ColorTable = colorTable;layer.hypsometricSetting = {hypsometricSetting: hyp,analysisMode: Cesium.HypsometricSettingEnum.AnalysisRegionMode.ARM_ALL}};

webgl端效果展示:
在这里插入图片描述
再通过box裁剪,选取合适的位置以及box的长、宽、高,实现对体元栅格X方向、Y方向、Z方向的剖切,下面以一个方向为例(其他类似):

var $length = $('#length');var $width = $('#width');var $height = $('#height');var $pointsize = $('#pointsize');var clipMode = "clip_behind_all_plane";$length.bind('input propertychange', function() {viewer.entities.removeAll();var length = Number($length.val());var width = 700;var height = 100;var boxOption = {dimensions: new Cesium.Cartesian3(length, width, height),position: new Cesium.Cartesian3.fromDegrees(116.4633797401118, 39.90879528431201, 25),clipMode: clipMode,heading: 0};var boxEntity = viewer.entities.add({box: {dimensions: new Cesium.Cartesian3(length, width, height),material: Cesium.Color.fromRandom({alpha: 0.01})},position: new Cesium.Cartesian3.fromDegrees(116.4633797401118, 39.90879528431201, 25),});setAllLayersClipOptions(boxOption);function setAllLayersClipOptions(boxOptions) {Gridlayer.setCustomClipBox(boxOptions);}var dim = boxEntity.box.dimensions.getValue();var newValue = Number($(this).val());boxEntity.box.dimensions = new Cesium.Cartesian3(newValue, dim.y, dim.z);setClipBox();function setClipBox() {var newDim = boxEntity.box.dimensions.getValue();var position = boxEntity.position.getValue(0);var boxOptions = {dimensions: newDim,position: position,};setAllLayersClipOptions(boxOptions);}});

注意事项:
1.构建体元栅格时,可根据需要设置合适的采样距离,不一定要与原始数据一致。设置的采样距离越小,生成的点越多,性能的消耗就越高。
2.WebGL 上的显示效果由体元栅格的采样距离与 pointSize 的大小共同决定。在满足显示效果的
前提下,可以通过增大采样距离,同时调大 pointSize 的值来减少性能的消耗。
3.体元栅格缓存支持 Box 裁剪,暂不支持多边形裁剪。

以下为效果展示

在这里插入图片描述


推荐阅读
  • 怎么在PHP项目中实现一个HTTP断点续传功能发布时间:2021-01-1916:26:06来源:亿速云阅读:96作者:Le ... [详细]
  • 本文由编程笔记#小编为大家整理,主要介绍了logistic回归(线性和非线性)相关的知识,包括线性logistic回归的代码和数据集的分布情况。希望对你有一定的参考价值。 ... [详细]
  • 本文介绍了brain的意思、读音、翻译、用法、发音、词组、同反义词等内容,以及脑新东方在线英语词典的相关信息。还包括了brain的词汇搭配、形容词和名词的用法,以及与brain相关的短语和词组。此外,还介绍了与brain相关的医学术语和智囊团等相关内容。 ... [详细]
  • 本文介绍了[从头学数学]中第101节关于比例的相关问题的研究和修炼过程。主要内容包括[机器小伟]和[工程师阿伟]一起研究比例的相关问题,并给出了一个求比例的函数scale的实现。 ... [详细]
  • 不同优化算法的比较分析及实验验证
    本文介绍了神经网络优化中常用的优化方法,包括学习率调整和梯度估计修正,并通过实验验证了不同优化算法的效果。实验结果表明,Adam算法在综合考虑学习率调整和梯度估计修正方面表现较好。该研究对于优化神经网络的训练过程具有指导意义。 ... [详细]
  • 本文介绍了机器学习手册中关于日期和时区操作的重要性以及其在实际应用中的作用。文章以一个故事为背景,描述了学童们面对老先生的教导时的反应,以及上官如在这个过程中的表现。同时,文章也提到了顾慎为对上官如的恨意以及他们之间的矛盾源于早年的结局。最后,文章强调了日期和时区操作在机器学习中的重要性,并指出了其在实际应用中的作用和意义。 ... [详细]
  • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • 本文介绍了在满足特定条件时如何在输入字段中使用默认值的方法和相应的代码。当输入字段填充100或更多的金额时,使用50作为默认值;当输入字段填充有-20或更多(负数)时,使用-10作为默认值。文章还提供了相关的JavaScript和Jquery代码,用于动态地根据条件使用默认值。 ... [详细]
  • 本文介绍了在PostgreSQL中批量导入数据时的优化方法。包括使用unlogged表、删除重建索引、删除重建外键、禁用触发器、使用COPY方法、批量插入等。同时还提到了一些参数优化的注意事项,如设置effective_cache_size、shared_buffer等,并强调了在导入大量数据后使用analyze命令重新收集统计信息的重要性。 ... [详细]
  • 本文介绍了游标的使用方法,并以一个水果供应商数据库为例进行了说明。首先创建了一个名为fruits的表,包含了水果的id、供应商id、名称和价格等字段。然后使用游标查询了水果的名称和价格,并将结果输出。最后对游标进行了关闭操作。通过本文可以了解到游标在数据库操作中的应用。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • 本文讨论了如何使用IF函数从基于有限输入列表的有限输出列表中获取输出,并提出了是否有更快/更有效的执行代码的方法。作者希望了解是否有办法缩短代码,并从自我开发的角度来看是否有更好的方法。提供的代码可以按原样工作,但作者想知道是否有更好的方法来执行这样的任务。 ... [详细]
  • 本文介绍了Python爬虫技术基础篇面向对象高级编程(中)中的多重继承概念。通过继承,子类可以扩展父类的功能。文章以动物类层次的设计为例,讨论了按照不同分类方式设计类层次的复杂性和多重继承的优势。最后给出了哺乳动物和鸟类的设计示例,以及能跑、能飞、宠物类和非宠物类的增加对类数量的影响。 ... [详细]
  • Day2列表、字典、集合操作详解
    本文详细介绍了列表、字典、集合的操作方法,包括定义列表、访问列表元素、字符串操作、字典操作、集合操作、文件操作、字符编码与转码等内容。内容详实,适合初学者参考。 ... [详细]
author-avatar
一路向北turbo
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有