zoukankan      html  css  js  c++  java
  • SLD 样式 之GeoServer中设计2.5维建筑物

    昨天GIS群里谈论到在GeoServer中创建google 、百度地图中的伪三维建筑物如:

    几番搜索,geoserver中用SLD的isometric可以实现这种效果:

    isometric geometry:Geometry,extrusion:Double Returns a multi-polygon containing the isometric extrusions of all segments part of the original geometry. The extrusion distance is extrusionand it’s assume to be expressed in the same unit as the geometry coordinates. Can be used to get a cheap pseudo-3d map effect

    具体的SLD文件为如下

    <?xml version="1.0" encoding="UTF-8"?>
    <StyledLayerDescriptor version="1.0.0"
      xmlns="http://www.opengis.net/sld" xmlns:ogc="http://www.opengis.net/ogc"
      xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://www.opengis.net/sld http://schemas.opengis.net/sld/1.0.0/StyledLayerDescriptor.xsd">
      <NamedLayer>
        <Name>alt-buildings</Name>
        <UserStyle>
          <FeatureTypeStyle>
            <Rule>
              <PolygonSymbolizer>
                <Geometry>
                  <ogc:Function name="isometric">
                    <ogc:PropertyName>geom</ogc:PropertyName>
                    <ogc:Literal>0.0001</ogc:Literal>
                  </ogc:Function>
                </Geometry>
                <Fill>
                  <CssParameter name="fill">#7B8F96</CssParameter>
                  <CssParameter name="fill-opacity">1</CssParameter>
                </Fill>
              </PolygonSymbolizer>
              <PolygonSymbolizer>
                <Geometry>
                  <ogc:Function name="offset">
                    <ogc:PropertyName>geom</ogc:PropertyName>
                    <ogc:Literal>0</ogc:Literal>
                    <ogc:Literal>0.0001</ogc:Literal>
                  </ogc:Function>
                </Geometry>
                <Fill>
                  <CssParameter name="fill">#BAD8E2</CssParameter>
                  <CssParameter name="fill-opacity">1</CssParameter>
                </Fill>
              </PolygonSymbolizer>
             </Rule>
          </FeatureTypeStyle>
          </UserStyle>
      </NamedLayer>
    </StyledLayerDescriptor>

    效果:

    这种情况下所有的建筑物的高度都是一样的 如果要实现高度不等具体操作如下:

    首先我的数据是从OpenStreetMap下载的并存到了PostGis数据库

    然后添加一个height字段默认值都为0.0001 并把上图最中间的那个半圆形建筑物的height改为0.0002

    然后修改sld文件把

    <ogc:Literal>0.0001</ogc:Literal>替换为<ogc:PropertyName>height</ogc:PropertyName>
    <?xml version="1.0" encoding="UTF-8"?>
    <StyledLayerDescriptor version="1.0.0"
      xmlns="http://www.opengis.net/sld" xmlns:ogc="http://www.opengis.net/ogc"
      xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
      xsi:schemaLocation="http://www.opengis.net/sld http://schemas.opengis.net/sld/1.0.0/StyledLayerDescriptor.xsd">
      <NamedLayer>
        <Name>alt-buildings</Name>
        <UserStyle>
          <FeatureTypeStyle>
            <Rule>
              <PolygonSymbolizer>
                <Geometry>
                  <ogc:Function name="isometric">
                    <ogc:PropertyName>geom</ogc:PropertyName>
                    <ogc:PropertyName>height</ogc:PropertyName>
                  </ogc:Function>
                </Geometry>
                <Fill>
                  <CssParameter name="fill">#7B8F96</CssParameter>
                  <CssParameter name="fill-opacity">1</CssParameter>
                </Fill>
                
              </PolygonSymbolizer>
              <PolygonSymbolizer>
                <Geometry>
                  <ogc:Function name="offset">
                    <ogc:PropertyName>geom</ogc:PropertyName>
                    <ogc:Literal>0</ogc:Literal>
                   <ogc:PropertyName>height</ogc:PropertyName>
                  </ogc:Function>
                </Geometry>
                <Fill>
                  <CssParameter name="fill">#BAD8E2</CssParameter>
                  <CssParameter name="fill-opacity">1</CssParameter>
                </Fill>
            
              </PolygonSymbolizer>
             </Rule>
          </FeatureTypeStyle>
          </UserStyle>
      </NamedLayer>
    </StyledLayerDescriptor>

    效果如下:

  • 相关阅读:
    MyBatisCodeHelper-Pro插件破解
    NO.1 用python打印你的宠物小精灵吧(python入门教程)
    类型转换
    VS2013无调试信息
    IP地址框
    map容器的使用
    MFC修改初始窗口大小和窗口名字禁止窗口最大,最小化
    Tensorflow之CNN卷积层池化层padding规则
    CNN之池化层tf.nn.max_pool | tf.nn.avg_pool | tf.reduce_mean | padding的规则解释
    tf.nn.conv2d卷积函数之图片轮廓提取
  • 原文地址:https://www.cnblogs.com/shitao/p/2661611.html
Copyright © 2011-2022 走看看