/* Copyright (c) 2006-2010 by OpenLayers Contributors (see authors.txt for * full list of contributors). Published under the Clear BSD license. * See http://svn.openlayers.org/trunk/openlayers/license.txt for the * full text of the license. */ /** * @requires OpenLayers/Layer/Vector.js * @requires OpenLayers/Request/XMLHttpRequest.js * @requires OpenLayers/Console.js */ /** * Class: OpenLayers.Layer.GML * Create a vector layer by parsing a GML file. The GML file is * passed in as a parameter. * *Deprecated*. To be removed in 3.0. Instead use OpenLayers.Layer.Vector * with Protocol.HTTP and Strategy.Fixed. Provide the protocol with a * format parameter to get the parser you want for your data. * * Inherits from: * - */ OpenLayers.Layer.GML = OpenLayers.Class(OpenLayers.Layer.Vector, { /** * Property: loaded * {Boolean} Flag for whether the GML data has been loaded yet. */ loaded: false, /** * APIProperty: format * {} The format you want the data to be parsed with. */ format: null, /** * APIProperty: formatOptions * {Object} Hash of options which should be passed to the format when it is * created. Must be passed in the constructor. */ formatOptions: null, /** * Constructor: OpenLayers.Layer.GML * Load and parse a single file on the web, according to the format * provided via the 'format' option, defaulting to GML. * * Parameters: * name - {String} * url - {String} URL of a GML file. * options - {Object} Hashtable of extra options to tag onto the layer. */ initialize: function(name, url, options) { var newArguments = []; newArguments.push(name, options); OpenLayers.Layer.Vector.prototype.initialize.apply(this, newArguments); this.url = url; }, /** * APIMethod: setVisibility * Set the visibility flag for the layer and hide/show&redraw accordingly. * Fire event unless otherwise specified * GML will be loaded if the layer is being made visible for the first * time. * * Parameters: * visible - {Boolean} Whether or not to display the layer * (if in range) * noEvent - {Boolean} */ setVisibility: function(visibility, noEvent) { OpenLayers.Layer.Vector.prototype.setVisibility.apply(this, arguments); if(this.visibility && !this.loaded){ // Load the GML this.loadGML(); } }, /** * Method: moveTo * If layer is visible and GML has not been loaded, load GML, then load GML * and call OpenLayers.Layer.Vector.moveTo() to redraw at the new location. * * Parameters: * bounds - {Object} * zoomChanged - {Object} * minor - {Object} */ moveTo:function(bounds, zoomChanged, minor) { OpenLayers.Layer.Vector.prototype.moveTo.apply(this, arguments); // Wait until initialisation is complete before loading GML // otherwise we can get a race condition where the root HTML DOM is // loaded after the GML is paited. // See http://trac.openlayers.org/ticket/404 if(this.visibility && !this.loaded){ this.loadGML(); } }, /** * Method: loadGML */ loadGML: function() { if (!this.loaded) { this.events.triggerEvent("loadstart"); OpenLayers.Request.GET({ url: this.url, success: this.requestSuccess, failure: this.requestFailure, scope: this }); this.loaded = true; } }, /** * Method: setUrl * Change the URL and reload the GML * * Parameters: * url - {String} URL of a GML file. */ setUrl:function(url) { this.url = url; this.destroyFeatures(); this.loaded = false; this.loadGML(); }, /** * Method: requestSuccess * Process GML after it has been loaded. * Called by initialize() and loadUrl() after the GML has been loaded. * * Parameters: * request - {String} */ requestSuccess:function(request) { var doc = request.responseXML; if (!doc || !doc.documentElement) { doc = request.responseText; } var options = {}; OpenLayers.Util.extend(options, this.formatOptions); if (this.map && !this.projection.equals(this.map.getProjectionObject())) { options.externalProjection = this.projection; options.internalProjection = this.map.getProjectionObject(); } var gml = this.format ? new this.format(options) : new OpenLayers.Format.GML(options); this.addFeatures(gml.read(doc)); this.events.triggerEvent("loadend"); }, /** * Method: requestFailure * Process a failed loading of GML. * Called by initialize() and loadUrl() if there was a problem loading GML. * * Parameters: * request - {String} */ requestFailure: function(request) { OpenLayers.Console.userError(OpenLayers.i18n("errorLoadingGML", {'url':this.url})); this.events.triggerEvent("loadend"); }, CLASS_NAME: "OpenLayers.Layer.GML" });