diff options
Diffstat (limited to 'misc/openlayers/lib/OpenLayers/Format/SLD/v1.js')
-rw-r--r-- | misc/openlayers/lib/OpenLayers/Format/SLD/v1.js | 1309 |
1 files changed, 0 insertions, 1309 deletions
diff --git a/misc/openlayers/lib/OpenLayers/Format/SLD/v1.js b/misc/openlayers/lib/OpenLayers/Format/SLD/v1.js deleted file mode 100644 index c43bac4..0000000 --- a/misc/openlayers/lib/OpenLayers/Format/SLD/v1.js +++ /dev/null @@ -1,1309 +0,0 @@ -/* Copyright (c) 2006-2013 by OpenLayers Contributors (see authors.txt for - * full list of contributors). Published under the 2-clause BSD license. - * See license.txt in the OpenLayers distribution or repository for the - * full text of the license. */ - -/** - * @requires OpenLayers/Rule.js - * @requires OpenLayers/Format/SLD.js - * @requires OpenLayers/Format/Filter/v1_0_0.js - * @requires OpenLayers/Symbolizer/Point.js - * @requires OpenLayers/Symbolizer/Line.js - * @requires OpenLayers/Symbolizer/Polygon.js - * @requires OpenLayers/Symbolizer/Text.js - * @requires OpenLayers/Symbolizer/Raster.js - */ - -/** - * Class: OpenLayers.Format.SLD.v1 - * Superclass for SLD version 1 parsers. - * - * Inherits from: - * - <OpenLayers.Format.Filter.v1_0_0> - */ -OpenLayers.Format.SLD.v1 = OpenLayers.Class(OpenLayers.Format.Filter.v1_0_0, { - - /** - * Property: namespaces - * {Object} Mapping of namespace aliases to namespace URIs. - */ - namespaces: { - sld: "http://www.opengis.net/sld", - ogc: "http://www.opengis.net/ogc", - gml: "http://www.opengis.net/gml", - xlink: "http://www.w3.org/1999/xlink", - xsi: "http://www.w3.org/2001/XMLSchema-instance" - }, - - /** - * Property: defaultPrefix - */ - defaultPrefix: "sld", - - /** - * Property: schemaLocation - * {String} Schema location for a particular minor version. - */ - schemaLocation: null, - - /** - * APIProperty: multipleSymbolizers - * {Boolean} Support multiple symbolizers per rule. Default is false. if - * true, an OpenLayers.Style2 instance will be created to represent - * user styles instead of an OpenLayers.Style instace. The - * OpenLayers.Style2 class allows collections of rules with multiple - * symbolizers, but is not currently useful for client side rendering. - * If multiple symbolizers is true, multiple FeatureTypeStyle elements - * are preserved in reading/writing by setting symbolizer zIndex values. - * In addition, the <defaultSymbolizer> property is ignored if - * multiple symbolizers are supported (defaults should be applied - * when rendering). - */ - multipleSymbolizers: false, - - /** - * Property: featureTypeCounter - * {Number} Private counter for multiple feature type styles. - */ - featureTypeCounter: null, - - /** - * APIProperty: defaultSymbolizer. - * {Object} A symbolizer with the SLD defaults. - */ - defaultSymbolizer: { - fillColor: "#808080", - fillOpacity: 1, - strokeColor: "#000000", - strokeOpacity: 1, - strokeWidth: 1, - strokeDashstyle: "solid", - pointRadius: 3, - graphicName: "square" - }, - - /** - * Constructor: OpenLayers.Format.SLD.v1 - * Instances of this class are not created directly. Use the - * <OpenLayers.Format.SLD> constructor instead. - * - * Parameters: - * options - {Object} An optional object whose properties will be set on - * this instance. - */ - - /** - * Method: read - * - * Parameters: - * data - {DOMElement} An SLD document element. - * options - {Object} Options for the reader. - * - * Valid options: - * namedLayersAsArray - {Boolean} Generate a namedLayers array. If false, - * the namedLayers property value will be an object keyed by layer name. - * Default is false. - * - * Returns: - * {Object} An object representing the SLD. - */ - read: function(data, options) { - options = OpenLayers.Util.applyDefaults(options, this.options); - var sld = { - namedLayers: options.namedLayersAsArray === true ? [] : {} - }; - this.readChildNodes(data, sld); - return sld; - }, - - /** - * Property: readers - * Contains public functions, grouped by namespace prefix, that will - * be applied when a namespaced node is found matching the function - * name. The function will be applied in the scope of this parser - * with two arguments: the node being read and a context object passed - * from the parent. - */ - readers: OpenLayers.Util.applyDefaults({ - "sld": { - "StyledLayerDescriptor": function(node, sld) { - sld.version = node.getAttribute("version"); - this.readChildNodes(node, sld); - }, - "Name": function(node, obj) { - obj.name = this.getChildValue(node); - }, - "Title": function(node, obj) { - obj.title = this.getChildValue(node); - }, - "Abstract": function(node, obj) { - obj.description = this.getChildValue(node); - }, - "NamedLayer": function(node, sld) { - var layer = { - userStyles: [], - namedStyles: [] - }; - this.readChildNodes(node, layer); - // give each of the user styles this layer name - for(var i=0, len=layer.userStyles.length; i<len; ++i) { - layer.userStyles[i].layerName = layer.name; - } - if(OpenLayers.Util.isArray(sld.namedLayers)) { - sld.namedLayers.push(layer); - } else { - sld.namedLayers[layer.name] = layer; - } - }, - "NamedStyle": function(node, layer) { - layer.namedStyles.push( - this.getChildName(node.firstChild) - ); - }, - "UserStyle": function(node, layer) { - var obj = {defaultsPerSymbolizer: true, rules: []}; - this.featureTypeCounter = -1; - this.readChildNodes(node, obj); - var style; - if (this.multipleSymbolizers) { - delete obj.defaultsPerSymbolizer; - style = new OpenLayers.Style2(obj); - } else { - style = new OpenLayers.Style(this.defaultSymbolizer, obj); - } - layer.userStyles.push(style); - }, - "IsDefault": function(node, style) { - if(this.getChildValue(node) == "1") { - style.isDefault = true; - } - }, - "FeatureTypeStyle": function(node, style) { - ++this.featureTypeCounter; - var obj = { - rules: this.multipleSymbolizers ? style.rules : [] - }; - this.readChildNodes(node, obj); - if (!this.multipleSymbolizers) { - style.rules = obj.rules; - } - }, - "Rule": function(node, obj) { - var config; - if (this.multipleSymbolizers) { - config = {symbolizers: []}; - } - var rule = new OpenLayers.Rule(config); - this.readChildNodes(node, rule); - obj.rules.push(rule); - }, - "ElseFilter": function(node, rule) { - rule.elseFilter = true; - }, - "MinScaleDenominator": function(node, rule) { - rule.minScaleDenominator = parseFloat(this.getChildValue(node)); - }, - "MaxScaleDenominator": function(node, rule) { - rule.maxScaleDenominator = parseFloat(this.getChildValue(node)); - }, - "TextSymbolizer": function(node, rule) { - var config = {}; - this.readChildNodes(node, config); - if (this.multipleSymbolizers) { - config.zIndex = this.featureTypeCounter; - rule.symbolizers.push( - new OpenLayers.Symbolizer.Text(config) - ); - } else { - rule.symbolizer["Text"] = OpenLayers.Util.applyDefaults( - config, rule.symbolizer["Text"] - ); - } - }, - "LabelPlacement": function(node, symbolizer) { - this.readChildNodes(node, symbolizer); - }, - "PointPlacement": function(node, symbolizer) { - var config = {}; - this.readChildNodes(node, config); - config.labelRotation = config.rotation; - delete config.rotation; - var labelAlign, - x = symbolizer.labelAnchorPointX, - y = symbolizer.labelAnchorPointY; - if (x <= 1/3) { - labelAlign = 'l'; - } else if (x > 1/3 && x < 2/3) { - labelAlign = 'c'; - } else if (x >= 2/3) { - labelAlign = 'r'; - } - if (y <= 1/3) { - labelAlign += 'b'; - } else if (y > 1/3 && y < 2/3) { - labelAlign += 'm'; - } else if (y >= 2/3) { - labelAlign += 't'; - } - config.labelAlign = labelAlign; - OpenLayers.Util.applyDefaults(symbolizer, config); - }, - "AnchorPoint": function(node, symbolizer) { - this.readChildNodes(node, symbolizer); - }, - "AnchorPointX": function(node, symbolizer) { - var labelAnchorPointX = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(labelAnchorPointX) { - symbolizer.labelAnchorPointX = labelAnchorPointX; - } - }, - "AnchorPointY": function(node, symbolizer) { - var labelAnchorPointY = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(labelAnchorPointY) { - symbolizer.labelAnchorPointY = labelAnchorPointY; - } - }, - "Displacement": function(node, symbolizer) { - this.readChildNodes(node, symbolizer); - }, - "DisplacementX": function(node, symbolizer) { - var labelXOffset = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(labelXOffset) { - symbolizer.labelXOffset = labelXOffset; - } - }, - "DisplacementY": function(node, symbolizer) { - var labelYOffset = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(labelYOffset) { - symbolizer.labelYOffset = labelYOffset; - } - }, - "LinePlacement": function(node, symbolizer) { - this.readChildNodes(node, symbolizer); - }, - "PerpendicularOffset": function(node, symbolizer) { - var labelPerpendicularOffset = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(labelPerpendicularOffset) { - symbolizer.labelPerpendicularOffset = labelPerpendicularOffset; - } - }, - "Label": function(node, symbolizer) { - var value = this.readers.ogc._expression.call(this, node); - if (value) { - symbolizer.label = value; - } - }, - "Font": function(node, symbolizer) { - this.readChildNodes(node, symbolizer); - }, - "Halo": function(node, symbolizer) { - // halo has a fill, so send fresh object - var obj = {}; - this.readChildNodes(node, obj); - symbolizer.haloRadius = obj.haloRadius; - symbolizer.haloColor = obj.fillColor; - symbolizer.haloOpacity = obj.fillOpacity; - }, - "Radius": function(node, symbolizer) { - var radius = this.readers.ogc._expression.call(this, node); - if(radius != null) { - // radius is only used for halo - symbolizer.haloRadius = radius; - } - }, - "RasterSymbolizer": function(node, rule) { - var config = {}; - this.readChildNodes(node, config); - if (this.multipleSymbolizers) { - config.zIndex = this.featureTypeCounter; - rule.symbolizers.push( - new OpenLayers.Symbolizer.Raster(config) - ); - } else { - rule.symbolizer["Raster"] = OpenLayers.Util.applyDefaults( - config, rule.symbolizer["Raster"] - ); - } - }, - "Geometry": function(node, obj) { - obj.geometry = {}; - this.readChildNodes(node, obj.geometry); - }, - "ColorMap": function(node, symbolizer) { - symbolizer.colorMap = []; - this.readChildNodes(node, symbolizer.colorMap); - }, - "ColorMapEntry": function(node, colorMap) { - var q = node.getAttribute("quantity"); - var o = node.getAttribute("opacity"); - colorMap.push({ - color: node.getAttribute("color"), - quantity: q !== null ? parseFloat(q) : undefined, - label: node.getAttribute("label") || undefined, - opacity: o !== null ? parseFloat(o) : undefined - }); - }, - "LineSymbolizer": function(node, rule) { - var config = {}; - this.readChildNodes(node, config); - if (this.multipleSymbolizers) { - config.zIndex = this.featureTypeCounter; - rule.symbolizers.push( - new OpenLayers.Symbolizer.Line(config) - ); - } else { - rule.symbolizer["Line"] = OpenLayers.Util.applyDefaults( - config, rule.symbolizer["Line"] - ); - } - }, - "PolygonSymbolizer": function(node, rule) { - var config = { - fill: false, - stroke: false - }; - if (!this.multipleSymbolizers) { - config = rule.symbolizer["Polygon"] || config; - } - this.readChildNodes(node, config); - if (this.multipleSymbolizers) { - config.zIndex = this.featureTypeCounter; - rule.symbolizers.push( - new OpenLayers.Symbolizer.Polygon(config) - ); - } else { - rule.symbolizer["Polygon"] = config; - } - }, - "PointSymbolizer": function(node, rule) { - var config = { - fill: false, - stroke: false, - graphic: false - }; - if (!this.multipleSymbolizers) { - config = rule.symbolizer["Point"] || config; - } - this.readChildNodes(node, config); - if (this.multipleSymbolizers) { - config.zIndex = this.featureTypeCounter; - rule.symbolizers.push( - new OpenLayers.Symbolizer.Point(config) - ); - } else { - rule.symbolizer["Point"] = config; - } - }, - "Stroke": function(node, symbolizer) { - symbolizer.stroke = true; - this.readChildNodes(node, symbolizer); - }, - "Fill": function(node, symbolizer) { - symbolizer.fill = true; - this.readChildNodes(node, symbolizer); - }, - "CssParameter": function(node, symbolizer) { - var cssProperty = node.getAttribute("name"); - var symProperty = this.cssMap[cssProperty]; - // for labels, fill should map to fontColor and fill-opacity - // to fontOpacity - if (symbolizer.label) { - if (cssProperty === 'fill') { - symProperty = "fontColor"; - } else if (cssProperty === 'fill-opacity') { - symProperty = "fontOpacity"; - } - } - if(symProperty) { - // Limited support for parsing of OGC expressions - var value = this.readers.ogc._expression.call(this, node); - // always string, could be an empty string - if(value) { - symbolizer[symProperty] = value; - } - } - }, - "Graphic": function(node, symbolizer) { - symbolizer.graphic = true; - var graphic = {}; - // painter's order not respected here, clobber previous with next - this.readChildNodes(node, graphic); - // directly properties with names that match symbolizer properties - var properties = [ - "stroke", "strokeColor", "strokeWidth", "strokeOpacity", - "strokeLinecap", "fill", "fillColor", "fillOpacity", - "graphicName", "rotation", "graphicFormat" - ]; - var prop, value; - for(var i=0, len=properties.length; i<len; ++i) { - prop = properties[i]; - value = graphic[prop]; - if(value != undefined) { - symbolizer[prop] = value; - } - } - // set other generic properties with specific graphic property names - if(graphic.opacity != undefined) { - symbolizer.graphicOpacity = graphic.opacity; - } - if(graphic.size != undefined) { - var pointRadius = graphic.size / 2; - if (isNaN(pointRadius)) { - // likely a property name - symbolizer.graphicWidth = graphic.size; - } else { - symbolizer.pointRadius = graphic.size / 2; - } - } - if(graphic.href != undefined) { - symbolizer.externalGraphic = graphic.href; - } - if(graphic.rotation != undefined) { - symbolizer.rotation = graphic.rotation; - } - }, - "ExternalGraphic": function(node, graphic) { - this.readChildNodes(node, graphic); - }, - "Mark": function(node, graphic) { - this.readChildNodes(node, graphic); - }, - "WellKnownName": function(node, graphic) { - graphic.graphicName = this.getChildValue(node); - }, - "Opacity": function(node, obj) { - var opacity = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(opacity) { - obj.opacity = opacity; - } - }, - "Size": function(node, obj) { - var size = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(size) { - obj.size = size; - } - }, - "Rotation": function(node, obj) { - var rotation = this.readers.ogc._expression.call(this, node); - // always string, could be empty string - if(rotation) { - obj.rotation = rotation; - } - }, - "OnlineResource": function(node, obj) { - obj.href = this.getAttributeNS( - node, this.namespaces.xlink, "href" - ); - }, - "Format": function(node, graphic) { - graphic.graphicFormat = this.getChildValue(node); - } - } - }, OpenLayers.Format.Filter.v1_0_0.prototype.readers), - - /** - * Property: cssMap - * {Object} Object mapping supported css property names to OpenLayers - * symbolizer property names. - */ - cssMap: { - "stroke": "strokeColor", - "stroke-opacity": "strokeOpacity", - "stroke-width": "strokeWidth", - "stroke-linecap": "strokeLinecap", - "stroke-dasharray": "strokeDashstyle", - "fill": "fillColor", - "fill-opacity": "fillOpacity", - "font-family": "fontFamily", - "font-size": "fontSize", - "font-weight": "fontWeight", - "font-style": "fontStyle" - }, - - /** - * Method: getCssProperty - * Given a symbolizer property, get the corresponding CSS property - * from the <cssMap>. - * - * Parameters: - * sym - {String} A symbolizer property name. - * - * Returns: - * {String} A CSS property name or null if none found. - */ - getCssProperty: function(sym) { - var css = null; - for(var prop in this.cssMap) { - if(this.cssMap[prop] == sym) { - css = prop; - break; - } - } - return css; - }, - - /** - * Method: getGraphicFormat - * Given a href for an external graphic, try to determine the mime-type. - * This method doesn't try too hard, and will fall back to - * <defaultGraphicFormat> if one of the known <graphicFormats> is not - * the file extension of the provided href. - * - * Parameters: - * href - {String} - * - * Returns: - * {String} The graphic format. - */ - getGraphicFormat: function(href) { - var format, regex; - for(var key in this.graphicFormats) { - if(this.graphicFormats[key].test(href)) { - format = key; - break; - } - } - return format || this.defaultGraphicFormat; - }, - - /** - * Property: defaultGraphicFormat - * {String} If none other can be determined from <getGraphicFormat>, this - * default will be returned. - */ - defaultGraphicFormat: "image/png", - - /** - * Property: graphicFormats - * {Object} Mapping of image mime-types to regular extensions matching - * well-known file extensions. - */ - graphicFormats: { - "image/jpeg": /\.jpe?g$/i, - "image/gif": /\.gif$/i, - "image/png": /\.png$/i - }, - - /** - * Method: write - * - * Parameters: - * sld - {Object} An object representing the SLD. - * - * Returns: - * {DOMElement} The root of an SLD document. - */ - write: function(sld) { - return this.writers.sld.StyledLayerDescriptor.apply(this, [sld]); - }, - - /** - * Property: writers - * As a compliment to the readers property, this structure contains public - * writing functions grouped by namespace alias and named like the - * node names they produce. - */ - writers: OpenLayers.Util.applyDefaults({ - "sld": { - "_OGCExpression": function(nodeName, value) { - // only the simplest of ogc:expression handled - // {label: "some text and a ${propertyName}"} - var node = this.createElementNSPlus(nodeName); - var tokens = typeof value == "string" ? - value.split("${") : - [value]; - node.appendChild(this.createTextNode(tokens[0])); - var item, last; - for(var i=1, len=tokens.length; i<len; i++) { - item = tokens[i]; - last = item.indexOf("}"); - if(last > 0) { - this.writeNode( - "ogc:PropertyName", - {property: item.substring(0, last)}, - node - ); - node.appendChild( - this.createTextNode(item.substring(++last)) - ); - } else { - // no ending }, so this is a literal ${ - node.appendChild( - this.createTextNode("${" + item) - ); - } - } - return node; - }, - "StyledLayerDescriptor": function(sld) { - var root = this.createElementNSPlus( - "sld:StyledLayerDescriptor", - {attributes: { - "version": this.VERSION, - "xsi:schemaLocation": this.schemaLocation - }} - ); - - // For ArcGIS Server it is necessary to define this - // at the root level (see ticket:2166). - root.setAttribute("xmlns:ogc", this.namespaces.ogc); - root.setAttribute("xmlns:gml", this.namespaces.gml); - - // add in optional name - if(sld.name) { - this.writeNode("Name", sld.name, root); - } - // add in optional title - if(sld.title) { - this.writeNode("Title", sld.title, root); - } - // add in optional description - if(sld.description) { - this.writeNode("Abstract", sld.description, root); - } - // add in named layers - // allow namedLayers to be an array - if(OpenLayers.Util.isArray(sld.namedLayers)) { - for(var i=0, len=sld.namedLayers.length; i<len; ++i) { - this.writeNode("NamedLayer", sld.namedLayers[i], root); - } - } else { - for(var name in sld.namedLayers) { - this.writeNode("NamedLayer", sld.namedLayers[name], root); - } - } - return root; - }, - "Name": function(name) { - return this.createElementNSPlus("sld:Name", {value: name}); - }, - "Title": function(title) { - return this.createElementNSPlus("sld:Title", {value: title}); - }, - "Abstract": function(description) { - return this.createElementNSPlus( - "sld:Abstract", {value: description} - ); - }, - "NamedLayer": function(layer) { - var node = this.createElementNSPlus("sld:NamedLayer"); - - // add in required name - this.writeNode("Name", layer.name, node); - - // optional sld:LayerFeatureConstraints here - - // add in named styles - if(layer.namedStyles) { - for(var i=0, len=layer.namedStyles.length; i<len; ++i) { - this.writeNode( - "NamedStyle", layer.namedStyles[i], node - ); - } - } - - // add in user styles - if(layer.userStyles) { - for(var i=0, len=layer.userStyles.length; i<len; ++i) { - this.writeNode( - "UserStyle", layer.userStyles[i], node - ); - } - } - - return node; - }, - "NamedStyle": function(name) { - var node = this.createElementNSPlus("sld:NamedStyle"); - this.writeNode("Name", name, node); - return node; - }, - "UserStyle": function(style) { - var node = this.createElementNSPlus("sld:UserStyle"); - - // add in optional name - if(style.name) { - this.writeNode("Name", style.name, node); - } - // add in optional title - if(style.title) { - this.writeNode("Title", style.title, node); - } - // add in optional description - if(style.description) { - this.writeNode("Abstract", style.description, node); - } - - // add isdefault - if(style.isDefault) { - this.writeNode("IsDefault", style.isDefault, node); - } - - // add FeatureTypeStyles - if (this.multipleSymbolizers && style.rules) { - // group style objects by symbolizer zIndex - var rulesByZ = { - 0: [] - }; - var zValues = [0]; - var rule, ruleMap, symbolizer, zIndex, clone; - for (var i=0, ii=style.rules.length; i<ii; ++i) { - rule = style.rules[i]; - if (rule.symbolizers) { - ruleMap = {}; - for (var j=0, jj=rule.symbolizers.length; j<jj; ++j) { - symbolizer = rule.symbolizers[j]; - zIndex = symbolizer.zIndex; - if (!(zIndex in ruleMap)) { - clone = rule.clone(); - clone.symbolizers = []; - ruleMap[zIndex] = clone; - } - ruleMap[zIndex].symbolizers.push(symbolizer.clone()); - } - for (zIndex in ruleMap) { - if (!(zIndex in rulesByZ)) { - zValues.push(zIndex); - rulesByZ[zIndex] = []; - } - rulesByZ[zIndex].push(ruleMap[zIndex]); - } - } else { - // no symbolizers in rule - rulesByZ[0].push(rule.clone()); - } - } - // write one FeatureTypeStyle per zIndex - zValues.sort(); - var rules; - for (var i=0, ii=zValues.length; i<ii; ++i) { - rules = rulesByZ[zValues[i]]; - if (rules.length > 0) { - clone = style.clone(); - clone.rules = rulesByZ[zValues[i]]; - this.writeNode("FeatureTypeStyle", clone, node); - } - } - } else { - this.writeNode("FeatureTypeStyle", style, node); - } - - return node; - }, - "IsDefault": function(bool) { - return this.createElementNSPlus( - "sld:IsDefault", {value: (bool) ? "1" : "0"} - ); - }, - "FeatureTypeStyle": function(style) { - var node = this.createElementNSPlus("sld:FeatureTypeStyle"); - - // OpenLayers currently stores no Name, Title, Abstract, - // FeatureTypeName, or SemanticTypeIdentifier information - // related to FeatureTypeStyle - - // add in rules - for(var i=0, len=style.rules.length; i<len; ++i) { - this.writeNode("Rule", style.rules[i], node); - } - - return node; - }, - "Rule": function(rule) { - var node = this.createElementNSPlus("sld:Rule"); - - // add in optional name - if(rule.name) { - this.writeNode("Name", rule.name, node); - } - // add in optional title - if(rule.title) { - this.writeNode("Title", rule.title, node); - } - // add in optional description - if(rule.description) { - this.writeNode("Abstract", rule.description, node); - } - - // add in LegendGraphic here - - // add in optional filters - if(rule.elseFilter) { - this.writeNode("ElseFilter", null, node); - } else if(rule.filter) { - this.writeNode("ogc:Filter", rule.filter, node); - } - - // add in scale limits - if(rule.minScaleDenominator != undefined) { - this.writeNode( - "MinScaleDenominator", rule.minScaleDenominator, node - ); - } - if(rule.maxScaleDenominator != undefined) { - this.writeNode( - "MaxScaleDenominator", rule.maxScaleDenominator, node - ); - } - - var type, symbolizer; - if (this.multipleSymbolizers && rule.symbolizers) { - var symbolizer; - for (var i=0, ii=rule.symbolizers.length; i<ii; ++i) { - symbolizer = rule.symbolizers[i]; - type = symbolizer.CLASS_NAME.split(".").pop(); - this.writeNode( - type + "Symbolizer", symbolizer, node - ); - } - } else { - // add in symbolizers (relies on geometry type keys) - var types = OpenLayers.Style.SYMBOLIZER_PREFIXES; - for(var i=0, len=types.length; i<len; ++i) { - type = types[i]; - symbolizer = rule.symbolizer[type]; - if(symbolizer) { - this.writeNode( - type + "Symbolizer", symbolizer, node - ); - } - } - } - return node; - - }, - "ElseFilter": function() { - return this.createElementNSPlus("sld:ElseFilter"); - }, - "MinScaleDenominator": function(scale) { - return this.createElementNSPlus( - "sld:MinScaleDenominator", {value: scale} - ); - }, - "MaxScaleDenominator": function(scale) { - return this.createElementNSPlus( - "sld:MaxScaleDenominator", {value: scale} - ); - }, - "LineSymbolizer": function(symbolizer) { - var node = this.createElementNSPlus("sld:LineSymbolizer"); - this.writeNode("Stroke", symbolizer, node); - return node; - }, - "Stroke": function(symbolizer) { - var node = this.createElementNSPlus("sld:Stroke"); - - // GraphicFill here - // GraphicStroke here - - // add in CssParameters - if(symbolizer.strokeColor != undefined) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "strokeColor"}, - node - ); - } - if(symbolizer.strokeOpacity != undefined) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "strokeOpacity"}, - node - ); - } - if(symbolizer.strokeWidth != undefined) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "strokeWidth"}, - node - ); - } - if(symbolizer.strokeDashstyle != undefined && symbolizer.strokeDashstyle !== "solid") { - // assumes valid stroke-dasharray value - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "strokeDashstyle"}, - node - ); - } - if(symbolizer.strokeLinecap != undefined) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "strokeLinecap"}, - node - ); - } - return node; - }, - "CssParameter": function(obj) { - // not handling ogc:expressions for now - return this.createElementNSPlus("sld:CssParameter", { - attributes: {name: this.getCssProperty(obj.key)}, - value: obj.symbolizer[obj.key] - }); - }, - "TextSymbolizer": function(symbolizer) { - var node = this.createElementNSPlus("sld:TextSymbolizer"); - // add in optional Label - if(symbolizer.label != null) { - this.writeNode("Label", symbolizer.label, node); - } - // add in optional Font - if(symbolizer.fontFamily != null || - symbolizer.fontSize != null || - symbolizer.fontWeight != null || - symbolizer.fontStyle != null) { - this.writeNode("Font", symbolizer, node); - } - // add in optional LabelPlacement - if (symbolizer.labelAnchorPointX != null || - symbolizer.labelAnchorPointY != null || - symbolizer.labelAlign != null || - symbolizer.labelXOffset != null || - symbolizer.labelYOffset != null || - symbolizer.labelRotation != null || - symbolizer.labelPerpendicularOffset != null) { - this.writeNode("LabelPlacement", symbolizer, node); - } - // add in optional Halo - if(symbolizer.haloRadius != null || - symbolizer.haloColor != null || - symbolizer.haloOpacity != null) { - this.writeNode("Halo", symbolizer, node); - } - // add in optional Fill - if(symbolizer.fontColor != null || - symbolizer.fontOpacity != null) { - this.writeNode("Fill", { - fillColor: symbolizer.fontColor, - fillOpacity: symbolizer.fontOpacity - }, node); - } - return node; - }, - "LabelPlacement": function(symbolizer) { - var node = this.createElementNSPlus("sld:LabelPlacement"); - // PointPlacement and LinePlacement are choices, so don't output both - if ((symbolizer.labelAnchorPointX != null || - symbolizer.labelAnchorPointY != null || - symbolizer.labelAlign != null || - symbolizer.labelXOffset != null || - symbolizer.labelYOffset != null || - symbolizer.labelRotation != null) && - symbolizer.labelPerpendicularOffset == null) { - this.writeNode("PointPlacement", symbolizer, node); - } - if (symbolizer.labelPerpendicularOffset != null) { - this.writeNode("LinePlacement", symbolizer, node); - } - return node; - }, - "LinePlacement": function(symbolizer) { - var node = this.createElementNSPlus("sld:LinePlacement"); - this.writeNode("PerpendicularOffset", symbolizer.labelPerpendicularOffset, node); - return node; - }, - "PerpendicularOffset": function(value) { - return this.createElementNSPlus("sld:PerpendicularOffset", { - value: value - }); - }, - "PointPlacement": function(symbolizer) { - var node = this.createElementNSPlus("sld:PointPlacement"); - if (symbolizer.labelAnchorPointX != null || - symbolizer.labelAnchorPointY != null || - symbolizer.labelAlign != null) { - this.writeNode("AnchorPoint", symbolizer, node); - } - if (symbolizer.labelXOffset != null || - symbolizer.labelYOffset != null) { - this.writeNode("Displacement", symbolizer, node); - } - if (symbolizer.labelRotation != null) { - this.writeNode("Rotation", symbolizer.labelRotation, node); - } - return node; - }, - "AnchorPoint": function(symbolizer) { - var node = this.createElementNSPlus("sld:AnchorPoint"); - var x = symbolizer.labelAnchorPointX, - y = symbolizer.labelAnchorPointY; - if (x != null) { - this.writeNode("AnchorPointX", x, node); - } - if (y != null) { - this.writeNode("AnchorPointY", y, node); - } - if (x == null && y == null) { - var xAlign = symbolizer.labelAlign.substr(0, 1), - yAlign = symbolizer.labelAlign.substr(1, 1); - if (xAlign === "l") { - x = 0; - } else if (xAlign === "c") { - x = 0.5; - } else if (xAlign === "r") { - x = 1; - } - if (yAlign === "b") { - y = 0; - } else if (yAlign === "m") { - y = 0.5; - } else if (yAlign === "t") { - y = 1; - } - this.writeNode("AnchorPointX", x, node); - this.writeNode("AnchorPointY", y, node); - } - return node; - }, - "AnchorPointX": function(value) { - return this.createElementNSPlus("sld:AnchorPointX", { - value: value - }); - }, - "AnchorPointY": function(value) { - return this.createElementNSPlus("sld:AnchorPointY", { - value: value - }); - }, - "Displacement": function(symbolizer) { - var node = this.createElementNSPlus("sld:Displacement"); - if (symbolizer.labelXOffset != null) { - this.writeNode("DisplacementX", symbolizer.labelXOffset, node); - } - if (symbolizer.labelYOffset != null) { - this.writeNode("DisplacementY", symbolizer.labelYOffset, node); - } - return node; - }, - "DisplacementX": function(value) { - return this.createElementNSPlus("sld:DisplacementX", { - value: value - }); - }, - "DisplacementY": function(value) { - return this.createElementNSPlus("sld:DisplacementY", { - value: value - }); - }, - "Font": function(symbolizer) { - var node = this.createElementNSPlus("sld:Font"); - // add in CssParameters - if(symbolizer.fontFamily) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "fontFamily"}, - node - ); - } - if(symbolizer.fontSize) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "fontSize"}, - node - ); - } - if(symbolizer.fontWeight) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "fontWeight"}, - node - ); - } - if(symbolizer.fontStyle) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "fontStyle"}, - node - ); - } - return node; - }, - "Label": function(label) { - return this.writers.sld._OGCExpression.call( - this, "sld:Label", label - ); - }, - "Halo": function(symbolizer) { - var node = this.createElementNSPlus("sld:Halo"); - if(symbolizer.haloRadius) { - this.writeNode("Radius", symbolizer.haloRadius, node); - } - if(symbolizer.haloColor || symbolizer.haloOpacity) { - this.writeNode("Fill", { - fillColor: symbolizer.haloColor, - fillOpacity: symbolizer.haloOpacity - }, node); - } - return node; - }, - "Radius": function(value) { - return this.createElementNSPlus("sld:Radius", { - value: value - }); - }, - "RasterSymbolizer": function(symbolizer) { - var node = this.createElementNSPlus("sld:RasterSymbolizer"); - if (symbolizer.geometry) { - this.writeNode("Geometry", symbolizer.geometry, node); - } - if (symbolizer.opacity) { - this.writeNode("Opacity", symbolizer.opacity, node); - } - if (symbolizer.colorMap) { - this.writeNode("ColorMap", symbolizer.colorMap, node); - } - return node; - }, - "Geometry": function(geometry) { - var node = this.createElementNSPlus("sld:Geometry"); - if (geometry.property) { - this.writeNode("ogc:PropertyName", geometry, node); - } - return node; - }, - "ColorMap": function(colorMap) { - var node = this.createElementNSPlus("sld:ColorMap"); - for (var i=0, len=colorMap.length; i<len; ++i) { - this.writeNode("ColorMapEntry", colorMap[i], node); - } - return node; - }, - "ColorMapEntry": function(colorMapEntry) { - var node = this.createElementNSPlus("sld:ColorMapEntry"); - var a = colorMapEntry; - node.setAttribute("color", a.color); - a.opacity !== undefined && node.setAttribute("opacity", - parseFloat(a.opacity)); - a.quantity !== undefined && node.setAttribute("quantity", - parseFloat(a.quantity)); - a.label !== undefined && node.setAttribute("label", a.label); - return node; - }, - "PolygonSymbolizer": function(symbolizer) { - var node = this.createElementNSPlus("sld:PolygonSymbolizer"); - if(symbolizer.fill !== false) { - this.writeNode("Fill", symbolizer, node); - } - if(symbolizer.stroke !== false) { - this.writeNode("Stroke", symbolizer, node); - } - return node; - }, - "Fill": function(symbolizer) { - var node = this.createElementNSPlus("sld:Fill"); - - // GraphicFill here - - // add in CssParameters - if(symbolizer.fillColor) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "fillColor"}, - node - ); - } - if(symbolizer.fillOpacity != null) { - this.writeNode( - "CssParameter", - {symbolizer: symbolizer, key: "fillOpacity"}, - node - ); - } - return node; - }, - "PointSymbolizer": function(symbolizer) { - var node = this.createElementNSPlus("sld:PointSymbolizer"); - this.writeNode("Graphic", symbolizer, node); - return node; - }, - "Graphic": function(symbolizer) { - var node = this.createElementNSPlus("sld:Graphic"); - if(symbolizer.externalGraphic != undefined) { - this.writeNode("ExternalGraphic", symbolizer, node); - } else { - this.writeNode("Mark", symbolizer, node); - } - - if(symbolizer.graphicOpacity != undefined) { - this.writeNode("Opacity", symbolizer.graphicOpacity, node); - } - if(symbolizer.pointRadius != undefined) { - this.writeNode("Size", symbolizer.pointRadius * 2, node); - } else if (symbolizer.graphicWidth != undefined) { - this.writeNode("Size", symbolizer.graphicWidth, node); - } - if(symbolizer.rotation != undefined) { - this.writeNode("Rotation", symbolizer.rotation, node); - } - return node; - }, - "ExternalGraphic": function(symbolizer) { - var node = this.createElementNSPlus("sld:ExternalGraphic"); - this.writeNode( - "OnlineResource", symbolizer.externalGraphic, node - ); - var format = symbolizer.graphicFormat || - this.getGraphicFormat(symbolizer.externalGraphic); - this.writeNode("Format", format, node); - return node; - }, - "Mark": function(symbolizer) { - var node = this.createElementNSPlus("sld:Mark"); - if(symbolizer.graphicName) { - this.writeNode("WellKnownName", symbolizer.graphicName, node); - } - if (symbolizer.fill !== false) { - this.writeNode("Fill", symbolizer, node); - } - if (symbolizer.stroke !== false) { - this.writeNode("Stroke", symbolizer, node); - } - return node; - }, - "WellKnownName": function(name) { - return this.createElementNSPlus("sld:WellKnownName", { - value: name - }); - }, - "Opacity": function(value) { - return this.createElementNSPlus("sld:Opacity", { - value: value - }); - }, - "Size": function(value) { - return this.writers.sld._OGCExpression.call( - this, "sld:Size", value - ); - }, - "Rotation": function(value) { - return this.createElementNSPlus("sld:Rotation", { - value: value - }); - }, - "OnlineResource": function(href) { - return this.createElementNSPlus("sld:OnlineResource", { - attributes: { - "xlink:type": "simple", - "xlink:href": href - } - }); - }, - "Format": function(format) { - return this.createElementNSPlus("sld:Format", { - value: format - }); - } - } - }, OpenLayers.Format.Filter.v1_0_0.prototype.writers), - - CLASS_NAME: "OpenLayers.Format.SLD.v1" - -}); |