255 lines
9.0 KiB
JavaScript
255 lines
9.0 KiB
JavaScript
/*
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU AFFERO General Public License as published by
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
or see http://www.gnu.org/licenses/agpl.txt.
|
|
*/
|
|
|
|
// OSRM initialization
|
|
// [initialization of maps, gui, image prefetching]
|
|
|
|
// will hold the Leaflet map object
|
|
OSRM.GLOBALS.map = null;
|
|
|
|
|
|
// onload initialization routine
|
|
OSRM.init = function() {
|
|
OSRM.prefetchImages();
|
|
OSRM.prefetchIcons();
|
|
|
|
OSRM.GUI.init();
|
|
OSRM.Routing.init();
|
|
OSRM.initMap();
|
|
|
|
// check if the URL contains some GET parameter, e.g. for showing a route
|
|
OSRM.checkURL();
|
|
};
|
|
|
|
|
|
// prefetch images
|
|
OSRM.GLOBALS.images = Array();
|
|
OSRM.prefetchImages = function() {
|
|
var images = [ 'images/marker-source.png',
|
|
'images/marker-target.png',
|
|
'images/marker-via.png',
|
|
'images/marker-highlight.png',
|
|
'images/cancel.png',
|
|
'images/cancel_active.png',
|
|
'images/cancel_hover.png',
|
|
'images/restore.png',
|
|
'images/restore_active.png',
|
|
'images/restore_hover.png'
|
|
];
|
|
|
|
for(var i=0; i<images.length; i++) {
|
|
OSRM.G.images[i] = new Image();
|
|
OSRM.G.images[i].src = images[i];
|
|
}
|
|
};
|
|
|
|
|
|
// prefetch icons
|
|
OSRM.GLOBALS.icons = Array();
|
|
OSRM.prefetchIcons = function() {
|
|
var images = [ 'marker-source',
|
|
'marker-target',
|
|
'marker-via',
|
|
'marker-highlight',
|
|
];
|
|
|
|
for(var i=0; i<images.length; i++)
|
|
OSRM.G.icons[images[i]] = new L.Icon('images/'+images[i]+'.png');
|
|
};
|
|
|
|
|
|
// centering on geolocation
|
|
function callback_centerOnGeolocation( position ) {
|
|
OSRM.G.map.setView( new L.LatLng( position.coords.latitude, position.coords.longitude), OSRM.DEFAULTS.ZOOM_LEVEL);
|
|
}
|
|
function centerOnGeolocation() {
|
|
if (navigator.geolocation)
|
|
navigator.geolocation.getCurrentPosition( callback_centerOnGeolocation );
|
|
}
|
|
|
|
|
|
// init map
|
|
OSRM.initMap = function() {
|
|
// TODO: check if GUI is initialized!
|
|
|
|
// setup tile servers
|
|
var osmorgURL = 'http://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
|
|
osmorgAttribution = 'Map data © 2011 OpenStreetMap contributors, Imagery © 2011 Mapnik',
|
|
osmorgOptions = {maxZoom: 18, attribution: osmorgAttribution};
|
|
|
|
var osmdeURL = 'http://{s}.tile.openstreetmap.de/tiles/osmde/{z}/{x}/{y}.png',
|
|
osmdeAttribution = 'Map data © 2011 OpenStreetMap contributors, Imagery © 2011 Mapnik',
|
|
osmdeOptions = {maxZoom: 18, attribution: osmdeAttribution};
|
|
|
|
var mapquestURL = 'http://otile{s}.mqcdn.com/tiles/1.0.0/osm/{z}/{x}/{y}.png',
|
|
mapquestAttribution = 'Map data © 2011 OpenStreetMap contributors, Imagery © 2011 MapQuest',
|
|
mapquestOptions = {maxZoom: 18, attribution: mapquestAttribution, subdomains: '1234'};
|
|
|
|
var cloudmadeURL = 'http://{s}.tile.cloudmade.com/BC9A493B41014CAABB98F0471D759707/997/256/{z}/{x}/{y}.png',
|
|
cloudmadeAttribution = 'Map data © 2011 OpenStreetMap contributors, Imagery © 2011 CloudMade',
|
|
cloudmadeOptions = {maxZoom: 18, attribution: cloudmadeAttribution};
|
|
|
|
var osmorg = new L.TileLayer(osmorgURL, osmorgOptions),
|
|
osmde = new L.TileLayer(osmdeURL, osmdeOptions),
|
|
mapquest = new L.TileLayer(mapquestURL, mapquestOptions),
|
|
cloudmade = new L.TileLayer(cloudmadeURL, cloudmadeOptions);
|
|
|
|
// setup map
|
|
OSRM.G.map = new L.Map('map', {
|
|
center: new L.LatLng(51.505, -0.09),
|
|
zoom: 13,
|
|
zoomAnimation: false, // false: removes animations and hiding of routes during zoom
|
|
fadeAnimation: false,
|
|
layers: [osmorg]
|
|
});
|
|
|
|
// add tileservers
|
|
var baseMaps = {
|
|
"osm.org": osmorg,
|
|
"osm.de": osmde,
|
|
"MapQuest": mapquest,
|
|
"CloudMade": cloudmade
|
|
};
|
|
|
|
var overlayMaps = {};
|
|
var layersControl = new L.Control.Layers(baseMaps, overlayMaps);
|
|
OSRM.G.map.addControl(layersControl);
|
|
|
|
// move zoom markers
|
|
getElementsByClassName(document,'leaflet-control-zoom')[0].style.left=(OSRM.GUI.width+10)+"px";
|
|
getElementsByClassName(document,'leaflet-control-zoom')[0].style.top="5px";
|
|
|
|
// initial map position and zoom
|
|
var position = new L.LatLng( OSRM.DEFAULTS.ONLOAD_LATITUDE, OSRM.DEFAULTS.ONLOAD_LONGITUDE);
|
|
if( OSRM.GUI.visible == true ) {
|
|
var point = OSRM.G.map.project( position, OSRM.DEFAULTS.ZOOM_LEVEL);
|
|
point.x-=OSRM.GUI.width/2;
|
|
position = OSRM.G.map.unproject(point,OSRM.DEFAULTS.ZOOM_LEVEL);
|
|
}
|
|
OSRM.G.map.setView( position, OSRM.DEFAULTS.ZOOM_LEVEL);
|
|
|
|
// map events
|
|
OSRM.G.map.on('zoomend', function(e) { OSRM.Routing.getRoute(OSRM.C.FULL_DESCRIPTION); });
|
|
OSRM.G.map.on('contextmenu', function(e) {});
|
|
OSRM.G.map.on('click', function(e) {
|
|
if( !OSRM.G.markers.hasSource() ) {
|
|
var index = OSRM.G.markers.setSource( e.latlng );
|
|
OSRM.Geocoder.updateAddress( OSRM.C.SOURCE_LABEL, OSRM.C.DO_FALLBACK_TO_LAT_LNG );
|
|
OSRM.G.markers.route[index].show();
|
|
OSRM.G.markers.route[index].centerView( OSRM.G.map.getZoom() );
|
|
OSRM.Routing.getRoute( OSRM.C.FULL_DESCRIPTION );
|
|
} else if( !OSRM.G.markers.hasTarget() ) {
|
|
var index = OSRM.G.markers.setTarget( e.latlng );
|
|
OSRM.Geocoder.updateAddress( OSRM.C.TARGET_LABEL, OSRM.C.DO_FALLBACK_TO_LAT_LNG );
|
|
OSRM.G.markers.route[index].show();
|
|
OSRM.G.markers.route[index].centerView( OSRM.G.map.getZoom() );
|
|
OSRM.Routing.getRoute( OSRM.C.FULL_DESCRIPTION );
|
|
}
|
|
} );
|
|
};
|
|
|
|
|
|
// parse URL GET parameters if any exist
|
|
OSRM.checkURL = function(){
|
|
var called_url = document.location.search.substr(1,document.location.search.length);
|
|
|
|
// reject messages that are clearly too long or too small
|
|
if( called_url.length > 1000 || called_url.length == 0)
|
|
return;
|
|
|
|
// storage for parameter values
|
|
var positions = [];
|
|
var zoom = null;
|
|
var center = null;
|
|
var destination = null;
|
|
var destination_name = null;
|
|
|
|
// parse input
|
|
var splitted_url = called_url.split('&');
|
|
for(var i=0; i<splitted_url.length; i++) {
|
|
var name_val = splitted_url[i].split('=');
|
|
if(name_val.length!=2)
|
|
continue;
|
|
|
|
if(name_val[0] == 'loc') {
|
|
var coordinates = unescape(name_val[1]).split(',');
|
|
if(coordinates.length!=2 || !OSRM.Utils.isLatitude(coordinates[0]) || !OSRM.Utils.isLongitude(coordinates[1]) )
|
|
return;
|
|
positions.push ( new L.LatLng( coordinates[0], coordinates[1]) );
|
|
}
|
|
else if(name_val[0] == 'dest') {
|
|
var coordinates = unescape(name_val[1]).split(',');
|
|
if(coordinates.length!=2 || !OSRM.Utils.isLatitude(coordinates[0]) || !OSRM.Utils.isLongitude(coordinates[1]) )
|
|
return;
|
|
destination = new L.LatLng( coordinates[0], coordinates[1]);
|
|
}
|
|
else if(name_val[0] == 'destname') {
|
|
destination_name = decodeURI(name_val[1]).replace(/<\/?[^>]+(>|$)/g ,""); // discard tags
|
|
}
|
|
else if(name_val[0] == 'z') {
|
|
zoom = name_val[1];
|
|
if( zoom<0 || zoom > 18)
|
|
return;
|
|
}
|
|
else if(name_val[0] == 'center') {
|
|
var coordinates = unescape(name_val[1]).split(',');
|
|
if(coordinates.length!=2 || !OSRM.Utils.isLatitude(coordinates[0]) || !OSRM.Utils.isLongitude(coordinates[1]) )
|
|
return;
|
|
center = new L.LatLng( coordinates[0], coordinates[1]);
|
|
}
|
|
}
|
|
|
|
// case 1: destination given
|
|
if( destination != undefined ) {
|
|
var index = OSRM.G.markers.setTarget( e.latlng );
|
|
if( destination_name == null )
|
|
OSRM.Geocoder.updateAddress( OSRM.C.TARGET_LABEL, OSRM.C.DO_FALLBACK_TO_LAT_LNG );
|
|
else
|
|
document.getElementById("input-target-name").value = destination_name;
|
|
OSRM.G.markers.route[index].show();
|
|
OSRM.G.markers.route[index].centerView();
|
|
return;
|
|
}
|
|
|
|
// case 2: locations given
|
|
if( positions != []) {
|
|
// draw via points
|
|
if( positions.length > 0) {
|
|
OSRM.G.markers.setSource( positions[0] );
|
|
OSRM.Geocoder.updateAddress( OSRM.C.SOURCE_LABEL, OSRM.C.DO_FALLBACK_TO_LAT_LNG );
|
|
}
|
|
if(positions.length > 1) {
|
|
OSRM.G.markers.setTarget( positions[positions.length-1] );
|
|
OSRM.Geocoder.updateAddress( OSRM.C.TARGET_LABEL, OSRM.C.DO_FALLBACK_TO_LAT_LNG );
|
|
}
|
|
for(var i=1; i<positions.length-1;i++)
|
|
OSRM.G.markers.setVia( i-1, positions[i] );
|
|
for(var i=0; i<OSRM.G.markers.route.length;i++)
|
|
OSRM.G.markers.route[i].show();
|
|
|
|
// center on route (support for old links) / move to given view (new behaviour)
|
|
if(zoom == null || center == null) {
|
|
var bounds = new L.LatLngBounds( positions );
|
|
OSRM.G.map.fitBounds( bounds );
|
|
} else {
|
|
OSRM.G.map.setView(center, zoom);
|
|
}
|
|
|
|
// compute route
|
|
OSRM.Routing.getRoute(OSRM.C.FULL_DESCRIPTION);
|
|
}
|
|
}; |