1.Styled Layer Descriptor
标准描述了稳当的结构合使用规则。一个文档包含了符号定义和绘制规则,那么这个文档就叫做Styled Layer Desciptor(SLD)样式,它是一个text/Xml文件,扩展名为.sld。SLD基于XML标记语言,附加的标准是一个XSD schema,XSD schema定义了SLD语法。
2.样式文档结构
样式最外层部分包含如下片段:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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">
第一行包含xml定义,每一个样式文件的根节点都为StyledLayerDescriptor,包含了样式标准的版本属性version(Geoserver可使用1.0.0和1.1.0 SLD版本),还包含了命名空间和模型属性。
StyledLayerDescriptor节点包含了一个NamedLayer或者UserLayer的集合,这两个节点下面又包含了UserStyle节点集合。
UserStyle节点下包含FeatureTypeStyle或者CoverageStyle节点。它们下面都包含了rule集合元素。rule节点定义了怎样绘制features。下面是一个简单的样式文件:
xml version="1.0" encoding="UTF-8"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld http://schemas.opengis.net/sld/1.0.0/StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>capitalsName> <UserStyle> <Name>capitalsName> <Title>Capital citiesTitle> <FeatureTypeStyle> <Rule> <Title>CapitalsTitle> <PointSymbolizer> <Graphic> <Mark> <WellKnownName>circleWellKnownName> <Fill> <CssParameter name="fill"> <ogc:Literal>#FFFFFFogc:Literal> CssParameter> Fill> <Stroke> <CssParameter name="stroke"> <ogc:Literal>#000000ogc:Literal> CssParameter> <CssParameter name="stroke-width"> <ogc:Literal>2ogc:Literal> CssParameter> Stroke> Mark> <Opacity> <ogc:Literal>1.0ogc:Literal> Opacity> <Size> <ogc:Literal>6ogc:Literal> Size> Graphic> PointSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
UserStyle定义了一个circle符号使用白色填充,黑色边界。WellKnownName包括:circle、square、triangle、star、cross、x。
使用geoserver-数据-Styles可查看配置并校验Style文件是否合法。
Rule节点下课包含多个PointSymbolizer,样式文件渲染顺序是倒序的,放在后面的PointSymbolizer渲染在地图上一层,前面的PointSymbolizer渲染在地图的下一层,相当于z-index的顺序。
3.实现一个点包含多个形状(包含多个PointSymbolizer)的样式例子
实现一个比较复杂的点的样式定义,显示效果如下:
样式定义如下:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>opulatedPlacesComplexName> <UserStyle> <Title>Geoserver Beginners Guide: mark composed of three basic shapesTitle> <FeatureTypeStyle> <Rule> <PointSymbolizer> <Graphic> <Mark> <WellKnownName>circleWellKnownName> <Fill> <CssParameter name="fill">#00FF00CssParameter> Fill> <Stroke> <CssParameter name="stroke">#000000CssParameter> <CssParameter name="stroke-width">1CssParameter> Stroke> Mark> <Size>16Size> Graphic> PointSymbolizer> <PointSymbolizer> <Graphic> <Mark> <WellKnownName>squareWellKnownName> <Fill> <CssParameter name="fill">#FF0000CssParameter> Fill> <Stroke> <CssParameter name="stroke">#000000CssParameter> <CssParameter name="stroke-width">1CssParameter> Stroke> Mark> <Size>10Size> Graphic> PointSymbolizer> <PointSymbolizer> <Graphic> <Mark> <WellKnownName>circleWellKnownName> <Fill> <CssParameter name="fill">#000000CssParameter> Fill> Mark> <Size>5Size> Graphic> PointSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
4.实现一个点包含外部资源形状(ExternalGraphic)的样式例子
显示的点通过一个外部svg图片来显示,效果如下:
样式定义如下:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>PopulatedPlacesGraphicName> <UserStyle> <Title>Geoserver Beginners Guide: Populated Places with external graphicsTitle> <FeatureTypeStyle> <Rule> <PointSymbolizer> <Graphic> <ExternalGraphic> <OnlineResource xlink:type="simple" xlink:href="town.svg"/> <Format>image/svg+xmlFormat> ExternalGraphic> <Size>20Size> Graphic> PointSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
如果想组合不同的符号,可通过Inkscape来设置图形样式,地址:https://inkscape.org/en/。
5.线条样式,大自然水渠的样式
想象输入去表达大自然的水渠?在地图中,水渠经常使用虚线和远点来表示。效果如下:
实现样式的Xml如下所示:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>DashingAndMarkersName> <UserStyle> <Title>Title>Geoserver Beginners Guide: Aqueducts with dashing and circleTitle> <FeatureTypeStyle> <Rule> <LineSymbolizer> <Stroke> <CssParameter name="stroke">#ADD8E6CssParameter> <CssParameter name="stroke-width">2CssParameter> <CssParameter name="stroke-dasharray">10 10CssParameter> Stroke> LineSymbolizer> <LineSymbolizer> <Stroke> <GraphicStroke> <Graphic> <Mark> <WellKnownName>circleWellKnownName> <Stroke> <CssParameter name="stroke">#ADD8E6CssParameter> <CssParameter name="stroke-width">1CssParameter> Stroke> Mark> <Size>5Size> Graphic> GraphicStroke> <CssParameter name="stroke-dasharray">5 15CssParameter> <CssParameter name="stroke-dashoffset">7.5CssParameter> Stroke> LineSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
第一个LineSymbolizer画出了虚线效果,第二个LineSymbolizer画出了圆点的效果。
6.多边形样式,使用阴影填充多边形
一般多边形都是通过边界和单一填充颜色来表示。但多边形也可以使用其他图形来作为阴影。下图给每个国家使用点来填充,效果如下:
实现样式的Xml文件内容如下:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>CountriesHatchingName> <UserStyle> <Title>Geoserver Beginners Guide: Countries with hatchingTitle> <FeatureTypeStyle> <Rule> <PolygonSymbolizer> <Fill> <GraphicFill> <Graphic> <Mark> <WellKnownName>shape://dotWellKnownName> <Stroke> <CssParameter name="stroke">#29A6A6CssParameter> <CssParameter name="stroke-width">3CssParameter> Stroke> Mark> <Size>16Size> Graphic> GraphicFill> Fill> <Stroke> <CssParameter name="stroke">#A52A2ACssParameter> <CssParameter name="stroke-width">2CssParameter> Stroke> PolygonSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
多边形的标记为PolygonSymbolizer,使用WellKnownName为shape://dot显示点效果。Stroke设置了点的边框颜色和大小。Geoserver为我们提供了很多标记效果。
shape://vertline:垂直线。
shape://horline: 水平线。
shape://slash: 对角线向前倾斜(“/”)。
shape://backslash:对角线向后斜线(“\”)。
shape://dot: 一个小的圆圈,圆圈之间有空隙。
shape://plus: 一个加号,加号之前没有空隙。
shape://times:一个“X”符号,没有空隙。
shape://oarrow:一个向外的箭头。
shape://carrow:一个向内 箭头。
7.在点上显示文字
在显示每个国家的首都时,一般都会在中心坐标显示首都名字,可通过字体标记来显示字体。效果如下:
实现样式的xml文件如下:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>PopulatedPlacesLabeledName> <UserStyle> <Title>Geoserver Beginners Guide: Populated Places with styled labelsTitle> <FeatureTypeStyle> <Rule> <PointSymbolizer> <Graphic> <Mark> <WellKnownName>circleWellKnownName> <Fill> <CssParameter name="fill">#FF0000CssParameter> Fill> <Stroke> <CssParameter name="stroke">#000000CssParameter> <CssParameter name="stroke-width">1CssParameter> Stroke> Mark> <Size>8Size> Graphic> PointSymbolizer> <TextSymbolizer> <Label> <ogc:PropertyName>NAMEogc:PropertyName> Label> <Font> <CssParameter name="font-family">ArialCssParameter> <CssParameter name="font-size">12CssParameter> <CssParameter name="font-style">normalCssParameter> <CssParameter name="font-weight">italycCssParameter> Font> <LabelPlacement> <PointPlacement> <AnchorPoint> <AnchorPointX>0AnchorPointX> <AnchorPointY>0AnchorPointY> AnchorPoint> <Displacement> <DisplacementX>2DisplacementX> <DisplacementY>5DisplacementY> Displacement> PointPlacement> LabelPlacement> <Fill> <CssParameter name="fill">#000000CssParameter> Fill> TextSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
8.在连线上显示文字
一般某一段线路都会对应有名称,显示效果如下:
实现样式的xml文件如下:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>RoadsLabeledName> <UserStyle> <Title>Title>Geoserver Beginners Guide: Roads with labels along the lineTitle> <FeatureTypeStyle> <Rule> <LineSymbolizer> <Stroke> <CssParameter name="stroke">#000000CssParameter> <CssParameter name="stroke-width">4CssParameter> Stroke> LineSymbolizer> <LineSymbolizer> <Stroke> <CssParameter name="stroke">#FF0000CssParameter> <CssParameter name="stroke-width">2CssParameter> Stroke> LineSymbolizer> <TextSymbolizer> <Label> <ogc:PropertyName>continentogc:PropertyName> Label> <LabelPlacement> <LinePlacement> <PerpendicularOffset>10PerpendicularOffset> LinePlacement> LabelPlacement> <Fill> <CssParameter name="fill">#000000CssParameter> Fill> <VendorOption name="followLine">trueVendorOption> <VendorOption name="maxAngleDelta">90VendorOption> <VendorOption name="maxDisplacement">400VendorOption> <VendorOption name="repeat">300VendorOption> TextSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
VendorOption设置一些文字的渲染参数,repeat表示道路显示文字的间隔距离,followLine设置文字是否颜色线路方向显示。
9.在多边形上显示文字
在每个国家的多边形边界中显示名称,效果如下:
实现效果的xml文件内容如下:
xml version="1.0" encoding="ISO-8859-1"?> <StyledLayerDescriptor version="1.0.0" xsi:schemaLocation="http://www.opengis.net/sld StyledLayerDescriptor.xsd" 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"> <NamedLayer> <Name>CountriesLabeledName> <UserStyle> <Title>Geoserver Beginners Guide: Countries with labelsTitle> <FeatureTypeStyle> <Rule> <PolygonSymbolizer> <Fill> <CssParameter name="fill">#29A6A6CssParameter> Fill> <Stroke> <CssParameter name="stroke">#A52A2ACssParameter> <CssParameter name="stroke-width">2CssParameter> Stroke> PolygonSymbolizer> <TextSymbolizer> <Label> <ogc:PropertyName>nameogc:PropertyName> Label> <Font> <CssParameter name="font-family">ArialCssParameter> <CssParameter name="font-size">11CssParameter> <CssParameter name="font-style">normalCssParameter> <CssParameter name="font-weight">boldCssParameter> Font> <LabelPlacement> <PointPlacement> <AnchorPoint> <AnchorPointX>0.5AnchorPointX> <AnchorPointY>0.5AnchorPointY> AnchorPoint> PointPlacement> LabelPlacement> <Fill> <CssParameter name="fill">#000000CssParameter> Fill> <VendorOption name="autoWrap">50VendorOption> <VendorOption name="maxDisplacement">150VendorOption> <Halo> <Radius>3Radius> <Fill> <CssParameter name="fill">#FFFFFFCssParameter> Fill> Halo> TextSymbolizer> Rule> FeatureTypeStyle> UserStyle> NamedLayer> StyledLayerDescriptor>
Halo节点下设置文字的阴影效果,geoserver校验该字段会失败,但是可以正常使用。