+ function getTileURL( bounds ) {
+ var res = this.map.getResolution();
+ var x = Math.round ((bounds.left - this.maxExtent.left) / (res * this.tileSize.w));
+ var y = Math.round ((this.maxExtent.top - bounds.top) / (res * this.tileSize.h));
+ var z = this.map.getZoom();
+ return this.url + z + "/" + x + "/" + y + "." + this.type;
+ }
+
+ function makeMarkerFunction( i ) {
+ return function() { markerOnClick( i ); };
+ }
+
+ function markerOnClick( i ) {
+ var html, position;
+ if( typeof( i ) == 'number' ) {
+ html = '<p>Nearby mapper: <a href="/user/'+nearest[i].display_name+'">'+nearest[i].display_name+'</a></p>';
+ html += '<p style="text-align:right">(<a href="#" onclick="return closePopup();">close</a>)</p>';
+ position = lonlat2mercator( new OpenLayers.LonLat( nearest[i].home_lon, nearest[i].home_lat ) );
+ } else {
+ html = '<p>Your location (<a href="#" onclick="return closePopup()">close</a>)</p>';
+ position = new OpenLayers.LonLat(mlon,mlat);
+ }
+ var box = document.getElementById( 'highlightinfo' );
+ box.innerHTML = html;
+ closePopup();
+ popup = new OpenLayers.Popup.AnchoredBubble( 'popup', position, new OpenLayers.Size( box.offsetWidth, box.offsetHeight ), html, OpenLayers.Marker.defaultIcon(), true );
+ map.addPopup( popup );
+ }
+
+ function closePopup() {
+ if( popup ) {
+ map.removePopup( popup );
+ delete popup;
+ }
+ return false;
+ }
+