--- /dev/null
+/* 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. */
+// @require: OpenLayers/Layer/Markers.js
+
+/**
+* @class
+*/
+OpenLayers.Layer.Text = Class.create();
+OpenLayers.Layer.Text.prototype =
+ Object.extend( new OpenLayers.Layer.Markers(), {
+
+ /** store url of text file
+ * @type str */
+ location:null,
+
+ /** @type Array(OpenLayers.Feature) */
+ features: null,
+
+ /** @type OpenLayers.Feature */
+ selectedFeature: null,
+
+ /**
+ * @constructor
+ *
+ * @param {String} name
+ * @param {String} location
+ */
+ initialize: function(name, location) {
+ OpenLayers.Layer.Markers.prototype.initialize.apply(this, [name]);
+ this.location = location;
+ this.features = new Array();
+ new Ajax.Request(location,
+ { method: 'get', onComplete:this.parseData.bind(this) } );
+ },
+
+ /**
+ *
+ */
+ destroy: function() {
+ this.clearFeatures();
+ this.features = null;
+ OpenLayers.Layer.Markers.prototype.destroy.apply(this, arguments);
+ },
+
+ /** WFS layer is never a base class.
+ * @type Boolean
+ */
+ isBaseLayer: function() {
+ return false;
+ },
+
+
+ /**
+ * @param {?} ajaxRequest
+ */
+ parseData: function(ajaxRequest) {
+ var text = ajaxRequest.responseText;
+ var lines = text.split('\n');
+ var columns;
+ // length - 1 to allow for trailing new line
+ for (var lcv = 0; lcv < (lines.length - 1); lcv++) {
+ var currLine = lines[lcv].replace(/^\s*/,'').replace(/\s*$/,'');
+
+ if (currLine.charAt(0) != '#') { /* not a comment */
+
+ if (!columns) {
+ //First line is columns
+ columns = currLine.split('\t');
+ } else {
+ var vals = currLine.split('\t');
+ var location = new OpenLayers.LonLat(0,0);
+ var title; var url;
+ var icon, iconSize, iconOffset;
+ var set = false;
+ for (var valIndex = 0; valIndex < vals.length; valIndex++) {
+ if (vals[valIndex]) {
+ if (columns[valIndex] == 'point') {
+ var coords = vals[valIndex].split(',');
+ location.lat = parseFloat(coords[0]);
+ location.lon = parseFloat(coords[1]);
+ set = true;
+ } else if (columns[valIndex] == 'lat') {
+ location.lat = parseFloat(vals[valIndex]);
+ set = true;
+ } else if (columns[valIndex] == 'lon') {
+ location.lon = parseFloat(vals[valIndex]);
+ set = true;
+ } else if (columns[valIndex] == 'title')
+ title = vals[valIndex];
+ else if (columns[valIndex] == 'image' ||
+ columns[valIndex] == 'icon')
+ url = vals[valIndex];
+ else if (columns[valIndex] == 'iconSize') {
+ var size = vals[valIndex].split(',');
+ iconSize = new OpenLayers.Size(parseFloat(size[0]),
+ parseFloat(size[1]));
+ } else if (columns[valIndex] == 'iconOffset') {
+ var offset = vals[valIndex].split(',');
+ iconOffset = new OpenLayers.Pixel(parseFloat(offset[0]),
+ parseFloat(offset[1]));
+ } else if (columns[valIndex] == 'title') {
+ title = vals[valIndex];
+ } else if (columns[valIndex] == 'description') {
+ description = vals[valIndex];
+ }
+ }
+ }
+ if (set) {
+ var data = new Object();
+ if (url != null) {
+ data.icon = new OpenLayers.Icon(url,
+ iconSize,
+ iconOffset);
+ } else {
+ data.icon = OpenLayers.Marker.defaultIcon();
+
+ //allows for the case where the image url is not
+ // specified but the size is. use a default icon
+ // but change the size
+ if (iconSize != null) {
+ data.icon.setSize(iconSize);
+ }
+
+ }
+ if ((title != null) && (description != null)) {
+ data['popupContentHTML'] = '<h2>'+title+'</h2><p>'+description+'</p>';
+ }
+ var feature = new OpenLayers.Feature(this, location, data);
+ this.features.append(feature);
+ var marker = feature.createMarker();
+ marker.events.register('click', feature, this.markerClick);
+ this.addMarker(marker);
+ }
+ }
+ }
+ }
+ },
+
+ /**
+ * @param {Event} evt
+ */
+ markerClick: function(evt) {
+ sameMarkerClicked = (this == this.layer.selectedFeature);
+ this.layer.selectedFeature = (!sameMarkerClicked) ? this : null;
+ for(var i=0; i < this.layer.map.popups.length; i++) {
+ this.layer.map.removePopup(this.layer.map.popups[i]);
+ }
+ if (!sameMarkerClicked) {
+ this.layer.map.addPopup(this.createPopup());
+ }
+ Event.stop(evt);
+ },
+
+ /**
+ *
+ */
+ clearFeatures: function() {
+ if (this.features != null) {
+ while(this.features.length > 0) {
+ var feature = this.features[0];
+ this.features.remove(feature);
+ feature.destroy();
+ }
+ }
+ },
+
+ /** @final @type String */
+ CLASS_NAME: "OpenLayers.Text"
+});
+
+