/* 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/Format/XML/VersionedOGC.js */ /** * Class: OpenLayers.Format.WMTSCapabilities * Read WMTS Capabilities. * * Inherits from: * - */ OpenLayers.Format.WMTSCapabilities = OpenLayers.Class(OpenLayers.Format.XML.VersionedOGC, { /** * APIProperty: defaultVersion * {String} Version number to assume if none found. Default is "1.0.0". */ defaultVersion: "1.0.0", /** * APIProperty: yx * {Object} Members in the yx object are used to determine if a CRS URN * corresponds to a CRS with y,x axis order. Member names are CRS URNs * and values are boolean. By default, the following CRS URN are * assumed to correspond to a CRS with y,x axis order: * * * urn:ogc:def:crs:EPSG::4326 */ yx: { "urn:ogc:def:crs:EPSG::4326": true }, /** * Constructor: OpenLayers.Format.WMTSCapabilities * Create a new parser for WMTS capabilities. * * Parameters: * options - {Object} An optional object whose properties will be set on * this instance. */ /** * APIMethod: read * Read capabilities data from a string, and return information about * the service (offering and observedProperty mostly). * * Parameters: * data - {String} or {DOMElement} data to read/parse. * * Returns: * {Object} Info about the WMTS Capabilities */ /** * APIMethod: createLayer * Create a WMTS layer given a capabilities object. * * Parameters: * capabilities - {Object} The object returned from a call to this * format. * config - {Object} Configuration properties for the layer. Defaults for * the layer will apply if not provided. * * Required config properties: * layer - {String} The layer identifier. * * Optional config properties: * matrixSet - {String} The matrix set identifier, required if there is * more than one matrix set in the layer capabilities. * style - {String} The name of the style * format - {String} Image format for the layer. Default is the first * format returned in the GetCapabilities response. * param - {Object} The dimensions values eg: {"Year": "2012"} * * Returns: * {} A properly configured WMTS layer. Throws an * error if an incomplete config is provided. Returns undefined if no * layer could be created with the provided config. */ createLayer: function(capabilities, config) { var layer; // confirm required properties are supplied in config if (!('layer' in config)) { throw new Error("Missing property 'layer' in configuration."); } var contents = capabilities.contents; // find the layer definition with the given identifier var layers = contents.layers; var layerDef; for (var i=0, ii=contents.layers.length; i= 1) { matrixSet = contents.tileMatrixSets[ layerDef.tileMatrixSetLinks[0].tileMatrixSet]; } if (!matrixSet) { throw new Error("matrixSet not found"); } // get the default style for the layer var style; for (var i=0, ii=layerDef.styles.length; i