关于mars3d通过zIndex参数实现控制图层层级叠加效果说明

问题:

1.项目中使用了GraphicLayer、GeoJSONLayer、ArcGISLayer,期望mars3d能够提供方法进行设置每个图层的zindex顺序

解决方案:

1.首先在mars3d的开发教程中查询三个Layer属于的图层类型,GraphicLayer、GeoJSONLayer均属于矢量图层,ArcGISLayer根据请求的服务类型不同可以分为瓦片图层与矢量数据图层。

Mars3D 三维可视化平台 | 火星科技 | 地图开发

Mars3D 三维可视化平台 | 火星科技 | 地图开发

2.首先需要了解的前置条件是,依据cesium的底层渲染机制,矢量数据永远在瓦片数据的上方,所以必须先弄清楚图层的类型是何种类型。

3.了解图层的类型后,期望控制图层的叠加顺序,可以考虑使用zindex参数来控制图层的叠加顺序。

3.1例如同时entity类型的矢量数据图层,可以在同为贴地的时候,设置zIndex数值来控制不同类型的叠加次序。

clampToGround: true,

zIndex: 999,

3.2如果是不同的数据类型,例如一个是entity类型,一个是primitive类型的矢量数据图层,就需要使用不同的高度值实现控制图层的叠加渲染的效果顺序。

可以考虑给positions的alt值一个准确的贴地的高程值。通过以下方法计算后,拿到数据给后端,让后端修改数据,通过渲染带准确的贴地的高程值的经纬度数据来实现不同图层的叠加效果控制。

1.相关计算方法:

http://mars3d.cn/api/PolyUtil.html?classFilter=polyutil#.computeSurfacePoints

2.相关方法的计算示例说明:

功能示例(Vue版) | Mars3D三维可视化平台 | 火星科技

3.补充说明:

一般我们的计算方法均可以在示例的map.js文件中搜索,例如搜索.computeSurfacePoints(,就可以快速找到相关参数方法的使用示例,学习后复制粘贴查看效果即可。

这也是快速学习了解mars3d.js的方法。

下载示例口令:

下载示例git clone https://gitee.com/marsgis/mars3d-vue-example.git

4.GeoJSONLayer、ArcGISLayer是不同的图层类型,一个是矢量数据类型一个是瓦片类型的话,此时就必须明确矢量数据一定是在瓦片数据的上方渲染的,那么此时如果期望控制图层的叠加效果,就需要更换数据类型,考虑将GeoJSONLayer从矢量数据图层换成瓦片数据图层后在与不同瓦片数据图层在一起通过zIndex值来进行控制叠加效果。

相关推荐
刘一说9 分钟前
CentOS 系统 Java 开发测试环境搭建手册
java·linux·运维·服务器·centos
卷福同学16 分钟前
来上海三个月,我在马路边上遇到了阿里前同事...
java·后端
Hy行者勇哥2 小时前
Python 与 VS Code 结合操作指南
开发语言·python
bingbingyihao2 小时前
多数据源 Demo
java·springboot
在努力的前端小白7 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
麦兜*8 小时前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3
萧鼎9 小时前
Python pyzmq 库详解:从入门到高性能分布式通信
开发语言·分布式·python
一叶飘零_sweeeet9 小时前
从繁琐到优雅:Java Lambda 表达式全解析与实战指南
java·lambda·java8
艾伦~耶格尔10 小时前
【集合框架LinkedList底层添加元素机制】
java·开发语言·学习·面试
新启航-光学3D测量10 小时前
从 48 小时到 4 小时:三维逆向工程中自动化工具链如何重构扫描建模效率
科技·3d·制造