热门标签 | 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 裁剪,暂不支持多边形裁剪。

以下为效果展示

在这里插入图片描述


推荐阅读
  • 本文详细介绍了MySQL数据库的基础语法与核心操作,涵盖从基础概念到具体应用的多个方面。首先,文章从基础知识入手,逐步深入到创建和修改数据表的操作。接着,详细讲解了如何进行数据的插入、更新与删除。在查询部分,不仅介绍了DISTINCT和LIMIT的使用方法,还探讨了排序、过滤和通配符的应用。此外,文章还涵盖了计算字段以及多种函数的使用,包括文本处理、日期和时间处理及数值处理等。通过这些内容,读者可以全面掌握MySQL数据库的核心操作技巧。 ... [详细]
  • Ihavetwomethodsofgeneratingmdistinctrandomnumbersintherange[0..n-1]我有两种方法在范围[0.n-1]中生 ... [详细]
  • 本文介绍如何使用 Python 的 DOM 和 SAX 方法解析 XML 文件,并通过示例展示了如何动态创建数据库表和处理大量数据的实时插入。 ... [详细]
  • 本文对比了杜甫《喜晴》的两种英文翻译版本:a. Pleased with Sunny Weather 和 b. Rejoicing in Clearing Weather。a 版由 alexcwlin 翻译并经 Adam Lam 编辑,b 版则由哈佛大学的宇文所安教授 (Prof. Stephen Owen) 翻译。 ... [详细]
  • php更新数据库字段的函数是,php更新数据库字段的函数是 ... [详细]
  • 在HTML布局中,即使将 `top: 0%` 和 `left: 0%` 设置为元素的定位属性,浏览器中仍然会出现空白填充。这个问题通常与默认的浏览器样式、盒模型或父元素的定位方式有关。为了消除这些空白,可以考虑重置浏览器的默认样式,确保父元素的定位方式正确,并检查是否有其他CSS规则影响了元素的位置。 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • 在Android应用开发中,实现与MySQL数据库的连接是一项重要的技术任务。本文详细介绍了Android连接MySQL数据库的操作流程和技术要点。首先,Android平台提供了SQLiteOpenHelper类作为数据库辅助工具,用于创建或打开数据库。开发者可以通过继承并扩展该类,实现对数据库的初始化和版本管理。此外,文章还探讨了使用第三方库如Retrofit或Volley进行网络请求,以及如何通过JSON格式交换数据,确保与MySQL服务器的高效通信。 ... [详细]
  • 在Java分层设计模式中,典型的三层架构(3-tier application)将业务应用细分为表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL)。这种分层结构不仅有助于提高代码的可维护性和可扩展性,还能有效分离关注点,使各层职责更加明确。通过合理的设计和实现,三层架构能够显著提升系统的整体性能和稳定性。 ... [详细]
  • 本文详细介绍了在 CentOS 7 系统中配置 fstab 文件以实现开机自动挂载 NFS 共享目录的方法,并解决了常见的配置失败问题。 ... [详细]
  • 本文介绍了在 Java 编程中遇到的一个常见错误:对象无法转换为 long 类型,并提供了详细的解决方案。 ... [详细]
  • 为了确保iOS应用能够安全地访问网站数据,本文介绍了如何在Nginx服务器上轻松配置CertBot以实现SSL证书的自动化管理。通过这一过程,可以确保应用始终使用HTTPS协议,从而提升数据传输的安全性和可靠性。文章详细阐述了配置步骤和常见问题的解决方法,帮助读者快速上手并成功部署SSL证书。 ... [详细]
  • 在Linux系统中,网络配置是至关重要的任务之一。本文详细解析了Firewalld和Netfilter机制,并探讨了iptables的应用。通过使用`ip addr show`命令来查看网卡IP地址(需要安装`iproute`包),当网卡未分配IP地址或处于关闭状态时,可以通过`ip link set`命令进行配置和激活。此外,文章还介绍了如何利用Firewalld和iptables实现网络流量控制和安全策略管理,为系统管理员提供了实用的操作指南。 ... [详细]
  • POJ 2482 星空中的星星:利用线段树与扫描线算法解决
    在《POJ 2482 星空中的星星》问题中,通过运用线段树和扫描线算法,可以高效地解决星星在窗口内的计数问题。该方法不仅能够快速处理大规模数据,还能确保时间复杂度的最优性,适用于各种复杂的星空模拟场景。 ... [详细]
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社区 版权所有