/* 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'] = '

'+title+'

'+description+'

'; } 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" });