/* Copyright (c) 2006 MetaCarta, Inc., published under the BSD license. * See http://svn.openlayers.org/trunk/openlayers/license.txt for the full * text of the license. */ /** * @class * * @requires OpenLayers/Layer/Grid.js * @requires OpenLayers/Layer/Markers.js */ OpenLayers.Layer.WFS = Class.create(); OpenLayers.Layer.WFS.prototype = Object.extend(new OpenLayers.Layer.Grid(), Object.extend(new OpenLayers.Layer.Markers(), { /** WFS layer is never a base layer. * * @type Boolean */ isBaseLayer: false, buffer: 1, /** Allow the user to specify special classes for features and tiles. * * This allows for easy-definition of behaviour. The defaults are * set here, but to override it, the property should be set via * the "options" parameter. */ /** @type Object */ featureClass: OpenLayers.Feature.WFS, /** @type Object */ tileClass: OpenLayers.Tile.WFS, /** Hashtable of default key/value parameters * @final @type Object */ DEFAULT_PARAMS: { service: "WFS", version: "1.0.0", request: "GetFeature", typename: "docpoint" }, /** * @constructor * * @param {String} name * @param {String} url * @param {Object} params * @param {Object} options Hashtable of extra options to tag onto the layer */ initialize: function(name, url, params, options) { var newArguments = new Array(); if (arguments.length > 0) { //uppercase params params = OpenLayers.Util.upperCaseObject(params); newArguments.push(name, url, params, options); } OpenLayers.Layer.Grid.prototype.initialize.apply(this, newArguments); var newArguments = new Array(); if (arguments.length > 0) { //uppercase params newArguments.push(name, options); } OpenLayers.Layer.Markers.prototype.initialize.apply(this, newArguments); if (arguments.length > 0) { OpenLayers.Util.applyDefaults( this.params, OpenLayers.Util.upperCaseObject(this.DEFAULT_PARAMS) ); } }, /** * */ destroy: function() { OpenLayers.Layer.Grid.prototype.destroy.apply(this, arguments); OpenLayers.Layer.Markers.prototype.destroy.apply(this, arguments); }, /** * @param {OpenLayers.Map} map */ setMap: function(map) { OpenLayers.Layer.Grid.prototype.setMap.apply(this, arguments); OpenLayers.Layer.Markers.prototype.setMap.apply(this, arguments); }, /** * @param {OpenLayers.Bounds} bounds * @param {Boolean} zoomChanged * @param {Boolean} minor */ moveTo:function(bounds, zoomChanged, minor) { OpenLayers.Layer.Grid.prototype.moveTo.apply(this, arguments); OpenLayers.Layer.Markers.prototype.moveTo.apply(this, arguments); }, /** * @param {Object} obj * * @returns An exact clone of this OpenLayers.Layer.WMS * @type OpenLayers.Layer.WMS */ clone: function (obj) { if (obj == null) { obj = new OpenLayers.Layer.WFS(this.name, this.url, this.params, this.options); } //get all additions from superclasses obj = OpenLayers.Layer.Grid.prototype.clone.apply(this, [obj]); // copy/set any non-init, non-simple values here return obj; }, /** * addTile creates a tile, initializes it (via 'draw' in this case), and * adds it to the layer div. * * @param {OpenLayers.Bounds} bounds * * @returns The added OpenLayers.Tile.WFS * @type OpenLayers.Tile.WFS */ addTile:function(bounds, position) { var urls = new Array(); //add standard URL urls.push( this.getFullRequestString() ); if (this.urls != null) { // if there are more urls, add them. for(var i=0; i < this.urls.length; i++) { urls.push( this.getFullRequestString(null, this.urls[i]) ); } } return new this.tileClass(this, position, bounds, urls, this.tileSize); }, /** * Catch changeParams and uppercase the new params to be merged in * before calling changeParams on the super class. * * Once params have been changed, we will need to re-init our tiles * * @param {Object} newParams Hashtable of new params to use */ mergeNewParams:function(newParams) { var upperParams = OpenLayers.Util.upperCaseObject(newParams); var newArguments = [upperParams]; OpenLayers.Layer.Grid.prototype.mergeNewParams.apply(this, newArguments); if (this.grid != null) { this._initTiles(); } }, /** combine the layer's url with its params and these newParams. * * Add the SRS parameter from getProjection() -- this is probably * more eloquently done via a setProjection() method, but this * works for now and always. * * @param {Object} newParams * * @type String */ getFullRequestString:function(newParams) { var projection = this.map.getProjection(); this.params.SRS = (projection == "none") ? null : projection; return OpenLayers.Layer.Grid.prototype.getFullRequestString.apply( this, arguments); }, /** * @param {String} featureID * * @returns The Feature, found within one of the layer's tiles' features * array, with a matching id. * If none found or if null passed-in, returns null * @type OpenLayers.Feature */ getFeature: function(featureID) { var foundFeature = null; if (featureID != null) { if (this.grid) { for(var iRow = 0; iRow < this.grid.length; iRow++) { var row = this.grid[iRow]; for(var iCol = 0; iCol < row.length; iCol++) { var tile = row[iCol]; for(var i=0; i < tile.features.length; i++) { var feature = tile.features[i]; if (feature.id == featureID) { foundFeature = feature; } } } } } } return foundFeature; }, /** @final @type String */ CLASS_NAME: "OpenLayers.Layer.WFS" } ) );