More trip planner testing with colors
[busui.git] / labs / openlayers / lib / OpenLayers / Layer / GML.js
blob:a/labs/openlayers/lib/OpenLayers/Layer/GML.js -> blob:b/labs/openlayers/lib/OpenLayers/Layer/GML.js
  /* 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.Vector>
  */
  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
  * {<OpenLayers.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"
  });