cesium入门示例-矢量化单体分类


实现楼层的分层选择和属性信息展示,该功能基于大雁塔倾斜数据实现单体化分类显示。

数据准备:

1、大雁塔倾斜数据,已转换为3dTiles,参考cesium入门示例-3dTiles加载的第2节osgb数据展示;

2、大雁塔分层多边形矢量图层shp文件;

分层矢量数据包含每一层的最大最小高度,每一层都是重合的矩形,在QGIS中打开如下(选择UTF-8编码):

在cesiumlab中将shp图层转换为3dTiles,设置如下:

 

注意cesiumlab的版本为1.5.17,低版本的可能会有问题。

数据准备完毕后即可在前端cesium框架中加载显示,加载代码很简单,如下:

 1 //西安大雁塔
 2 var dayantaTileset = new Cesium.Cesium3DTileset({
 3     url: './TestData/output/osgbtiles/tileset.json'
 4 })
 5 viewer.scene.primitives.add(dayantaTileset);
 6 //大雁塔矢量单体
 7 var classifytileset = new Cesium.Cesium3DTileset({
 8     url: './TestData/output/dayantaclassify/tileset.json',
 9     classificationType: Cesium.ClassificationType.CESIUM_3D_TILE
10 });
11 //注意这个颜色的设置
12 classifytileset.style = new Cesium.Cesium3DTileStyle({
13     color: 'rgba(255, 0, 0, 0.5)'//,增加要素选择效果后,将原始颜色透明度调到几乎看不到,改为'rgba(255, 0, 0, 0.01)'
14 }); 15 viewer.scene.primitives.add(classifytileset);

 然后增加分层选择效果,选择显示属性信息通过侦听鼠标MOVE和LEFT_CLICK事件,查询要素获得,具体代码参照cesium入门示例-3dTiles加载的3节。最终效果如下:

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM