zoukankan      html  css  js  c++  java
  • 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节。最终效果如下:

  • 相关阅读:
    FileWriter写数据路径问题及关闭和刷新方法的区别
    FileWriter剖析
    2018-10-27 22:44:33 c language
    2018-10-23 23:29:54 clanguage
    Just write about
    2018-10-19 00:13:35 ArrayList
    2018-10-18 22:15:32 c language
    Why do collection classes appear
    2018-10-17 22:20:39 c language
    2018-10-16 22:56:13 c language
  • 原文地址:https://www.cnblogs.com/HandyLi/p/11125275.html
Copyright © 2011-2022 走看看