Merge branch 'trial/alternatives' into develop
Conflicts: WebContent/routing/OSRM.Routing.js
This commit is contained in:
commit
4ebe4848af
@ -81,7 +81,7 @@ zoomed: function(e) {
|
|||||||
if(OSRM.G.dragging)
|
if(OSRM.G.dragging)
|
||||||
OSRM.Routing.getRoute_Dragging();
|
OSRM.Routing.getRoute_Dragging();
|
||||||
else
|
else
|
||||||
OSRM.Routing.getRoute_Redraw();
|
OSRM.Routing.getRoute_Redraw({keepAlternative:true});
|
||||||
},
|
},
|
||||||
contextmenu: function(e) {;},
|
contextmenu: function(e) {;},
|
||||||
mousemove: function(e) { OSRM.Via.drawDragMarker(e); },
|
mousemove: function(e) { OSRM.Via.drawDragMarker(e); },
|
||||||
|
@ -20,9 +20,10 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
|
|
||||||
|
|
||||||
OSRM.Route = function() {
|
OSRM.Route = function() {
|
||||||
this._current_route = new OSRM.SimpleRoute("current" , {dashed:false} );
|
this._current_route = new OSRM.SimpleRoute("current" , {dashed:false} );
|
||||||
this._old_route = new OSRM.SimpleRoute("old", {dashed:false,color:"#123"} );
|
this._alternative_route = new OSRM.SimpleRoute("alternative" , {dashed:false} );
|
||||||
this._unnamed_route = new OSRM.MultiRoute("unnamed");
|
this._old_route = new OSRM.SimpleRoute("old", {dashed:false,color:"#123"} );
|
||||||
|
this._unnamed_route = new OSRM.MultiRoute("unnamed");
|
||||||
|
|
||||||
this._current_route_style = {dashed:false,color:'#0033FF', weight:5};
|
this._current_route_style = {dashed:false,color:'#0033FF', weight:5};
|
||||||
this._current_noroute_style = {dashed:true, color:'#222222', weight:2};
|
this._current_noroute_style = {dashed:true, color:'#222222', weight:2};
|
||||||
@ -30,6 +31,7 @@ OSRM.Route = function() {
|
|||||||
this._old_noroute_style = {dashed:true, color:'#000000', weight:2};
|
this._old_noroute_style = {dashed:true, color:'#000000', weight:2};
|
||||||
this._unnamed_route_style = {dashed:false, color:'#FF00FF', weight:10};
|
this._unnamed_route_style = {dashed:false, color:'#FF00FF', weight:10};
|
||||||
this._old_unnamed_route_style = {dashed:false, color:'#990099', weight:10};
|
this._old_unnamed_route_style = {dashed:false, color:'#990099', weight:10};
|
||||||
|
this._alternative_route_style = {dashed:false,color:'#770033', weight:5, opacity:0.6};
|
||||||
|
|
||||||
this._noroute = OSRM.Route.ROUTE;
|
this._noroute = OSRM.Route.ROUTE;
|
||||||
this._history = new OSRM.HistoryRoute();
|
this._history = new OSRM.HistoryRoute();
|
||||||
@ -99,6 +101,16 @@ OSRM.extend( OSRM.Route,{
|
|||||||
this._old_route.hide();
|
this._old_route.hide();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
// show/hide alternative route
|
||||||
|
showAlternativeRoute: function(positions) {
|
||||||
|
this._alternative_route.setPositions( positions );
|
||||||
|
this._alternative_route.setStyle( this._alternative_route_style );
|
||||||
|
this._alternative_route.show();
|
||||||
|
},
|
||||||
|
hideAlternativeRoute: function() {
|
||||||
|
this._alternative_route.hide();
|
||||||
|
},
|
||||||
|
|
||||||
// query routines
|
// query routines
|
||||||
isShown: function() {
|
isShown: function() {
|
||||||
return this._current_route.isShown();
|
return this._current_route.isShown();
|
||||||
|
@ -101,7 +101,7 @@ afterMainTransition: function() {
|
|||||||
// toggle distance units
|
// toggle distance units
|
||||||
onUnitsChanged: function(value) {
|
onUnitsChanged: function(value) {
|
||||||
OSRM.Utils.setToHumanDistanceFunction(value);
|
OSRM.Utils.setToHumanDistanceFunction(value);
|
||||||
OSRM.Routing.getRoute();
|
OSRM.Routing.getRoute({keepAlternative:true});
|
||||||
},
|
},
|
||||||
|
|
||||||
// set timestamp of data
|
// set timestamp of data
|
||||||
|
@ -40,7 +40,7 @@ init: function() {
|
|||||||
document.getElementById("gui-reverse").onclick = OSRM.GUI.reverseRouting;
|
document.getElementById("gui-reverse").onclick = OSRM.GUI.reverseRouting;
|
||||||
document.getElementById("open-josm").onclick = OSRM.GUI.openJOSM;
|
document.getElementById("open-josm").onclick = OSRM.GUI.openJOSM;
|
||||||
document.getElementById("open-osmbugs").onclick = OSRM.GUI.openOSMBugs;
|
document.getElementById("open-osmbugs").onclick = OSRM.GUI.openOSMBugs;
|
||||||
document.getElementById("option-highlight-nonames").onclick = OSRM.Routing.getRoute_Redraw;
|
document.getElementById("option-highlight-nonames").onclick = OSRM.GUI.hightlightNonames;
|
||||||
document.getElementById("option-show-previous-routes").onclick = OSRM.GUI.showPreviousRoutes;
|
document.getElementById("option-show-previous-routes").onclick = OSRM.GUI.showPreviousRoutes;
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -164,6 +164,11 @@ zoomOnRoute: function() {
|
|||||||
|
|
||||||
var bounds = new L.LatLngBounds( OSRM.G.route._current_route.getPositions() );
|
var bounds = new L.LatLngBounds( OSRM.G.route._current_route.getPositions() );
|
||||||
OSRM.G.map.fitBoundsUI(bounds);
|
OSRM.G.map.fitBoundsUI(bounds);
|
||||||
|
},
|
||||||
|
|
||||||
|
//click: toggle highlighting unnamed streets
|
||||||
|
hightlightNonames: function() {
|
||||||
|
OSRM.Routing.getRoute_Redraw({keepAlternative:true});
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -64,7 +64,7 @@ setLanguage: function(language) {
|
|||||||
if( OSRM.G.markers == null )
|
if( OSRM.G.markers == null )
|
||||||
return;
|
return;
|
||||||
if( OSRM.G.markers.route.length > 1)
|
if( OSRM.G.markers.route.length > 1)
|
||||||
OSRM.Routing.getRoute();
|
OSRM.Routing.getRoute({keepAlternative:true});
|
||||||
else if(OSRM.G.markers.route.length > 0 && document.getElementById('information-box').innerHTML != "" ) {
|
else if(OSRM.G.markers.route.length > 0 && document.getElementById('information-box').innerHTML != "" ) {
|
||||||
OSRM.Geocoder.call( OSRM.C.SOURCE_LABEL, document.getElementById("gui-input-source").value );
|
OSRM.Geocoder.call( OSRM.C.SOURCE_LABEL, document.getElementById("gui-input-source").value );
|
||||||
OSRM.Geocoder.call( OSRM.C.TARGET_LABEL, document.getElementById("gui-input-target").value );
|
OSRM.Geocoder.call( OSRM.C.TARGET_LABEL, document.getElementById("gui-input-target").value );
|
||||||
|
@ -536,6 +536,21 @@ html, body {
|
|||||||
outline-style:none;
|
outline-style:none;
|
||||||
vertical-align:1px;
|
vertical-align:1px;
|
||||||
}
|
}
|
||||||
|
.button-pressed
|
||||||
|
{
|
||||||
|
cursor:pointer;
|
||||||
|
padding:2px 10px 2px 10px;
|
||||||
|
border-radius:5px;
|
||||||
|
-moz-border-radius:5px;
|
||||||
|
-webkit-border-radius:5px;
|
||||||
|
background-color:#AAAAAA;
|
||||||
|
border:1px solid #999999;
|
||||||
|
color:#000000;
|
||||||
|
text-decoration:none;
|
||||||
|
font-size:9px;
|
||||||
|
outline-style:none;
|
||||||
|
vertical-align:1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* iconic buttons */
|
/* iconic buttons */
|
||||||
|
@ -65,6 +65,7 @@ or see http://www.gnu.org/licenses/agpl.txt.
|
|||||||
<script src="gui/OSRM.Selector.js" type="text/javascript"></script>
|
<script src="gui/OSRM.Selector.js" type="text/javascript"></script>
|
||||||
<script src="gui/OSRM.MainGUI.js" type="text/javascript"></script>
|
<script src="gui/OSRM.MainGUI.js" type="text/javascript"></script>
|
||||||
<script src="routing/OSRM.Routing.js" type="text/javascript"></script>
|
<script src="routing/OSRM.Routing.js" type="text/javascript"></script>
|
||||||
|
<script src="routing/OSRM.RoutingAlternatives.js" type="text/javascript"></script>
|
||||||
<script src="routing/OSRM.RoutingDescription.js" type="text/javascript"></script>
|
<script src="routing/OSRM.RoutingDescription.js" type="text/javascript"></script>
|
||||||
<script src="routing/OSRM.RoutingGeometry.js" type="text/javascript"></script>
|
<script src="routing/OSRM.RoutingGeometry.js" type="text/javascript"></script>
|
||||||
<script src="gui/OSRM.RoutingGUI.js" type="text/javascript"></script>
|
<script src="gui/OSRM.RoutingGUI.js" type="text/javascript"></script>
|
||||||
|
@ -29,6 +29,7 @@ OSRM.init = function() {
|
|||||||
OSRM.Map.init();
|
OSRM.Map.init();
|
||||||
OSRM.Printing.init();
|
OSRM.Printing.init();
|
||||||
OSRM.Routing.init();
|
OSRM.Routing.init();
|
||||||
|
OSRM.RoutingAlternatives.init();
|
||||||
OSRM.Localization.init();
|
OSRM.Localization.init();
|
||||||
|
|
||||||
// stop if in maintenance mode
|
// stop if in maintenance mode
|
||||||
@ -216,7 +217,13 @@ OSRM.parseParameters = function(){
|
|||||||
if(coordinates.length!=2 || !OSRM.Utils.isLatitude(coordinates[0]) || !OSRM.Utils.isLongitude(coordinates[1]) )
|
if(coordinates.length!=2 || !OSRM.Utils.isLatitude(coordinates[0]) || !OSRM.Utils.isLongitude(coordinates[1]) )
|
||||||
return;
|
return;
|
||||||
params.center = new L.LatLng( coordinates[0], coordinates[1]);
|
params.center = new L.LatLng( coordinates[0], coordinates[1]);
|
||||||
}
|
}
|
||||||
|
else if(name_val[0] == 'alt') {
|
||||||
|
var active_alternative = Number(name_val[1]);
|
||||||
|
if( active_alternative<0 || active_alternative>OSRM.RoutingAlternatives>10) // using 10 as arbitrary upper limit
|
||||||
|
return;
|
||||||
|
params.active_alternative = active_alternative;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// case 1: destination given
|
// case 1: destination given
|
||||||
@ -255,9 +262,12 @@ OSRM.parseParameters = function(){
|
|||||||
} else {
|
} else {
|
||||||
OSRM.G.map.setView(params.center, params.zoom);
|
OSRM.G.map.setView(params.center, params.zoom);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set active alternative (if via points are set or alternative does not exists: automatic fallback to shortest route)
|
||||||
|
OSRM.G.active_alternative = params.active_alternative;
|
||||||
|
|
||||||
// compute route
|
// compute route
|
||||||
OSRM.Routing.getRoute();
|
OSRM.Routing.getRoute({keepAlternative:true});
|
||||||
OSRM.G.initial_position_override = true;
|
OSRM.G.initial_position_override = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -280,4 +290,4 @@ OSRM.inMaintenance = function(){
|
|||||||
};
|
};
|
||||||
|
|
||||||
// onload event
|
// onload event
|
||||||
OSRM.Browser.onLoadHandler( OSRM.init );
|
OSRM.Browser.onLoadHandler( OSRM.init );
|
||||||
|
@ -187,13 +187,17 @@ show: function(response) {
|
|||||||
// draw route & query for better geometry
|
// draw route & query for better geometry
|
||||||
print_window.OSRM.drawRoute( positions );
|
print_window.OSRM.drawRoute( positions );
|
||||||
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&z='+zoom+'&instructions=false', OSRM.Printing.drawRoute, OSRM.Printing.timeoutRoute, OSRM.DEFAULTS.JSONP_TIMEOUT, 'print');
|
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&z='+zoom+'&instructions=false', OSRM.Printing.drawRoute, OSRM.Printing.timeoutRoute, OSRM.DEFAULTS.JSONP_TIMEOUT, 'print');
|
||||||
// NOTE: simply appended correct zoom level as second zoom parameter to JSONP call -> OSRM API only considers the last one!
|
// NOTE: correct zoom level was appended as second zoom parameter to JSONP call -> OSRM API only considers the last one!
|
||||||
},
|
},
|
||||||
timeoutRoute: function() {},
|
timeoutRoute: function() {},
|
||||||
drawRoute: function(response) {
|
drawRoute: function(response) {
|
||||||
if(!response)
|
if(!response)
|
||||||
return;
|
return;
|
||||||
var positions = OSRM.RoutingGeometry._decode(response.route_geometry, 5);
|
|
||||||
|
response.alternative_geometries.unshift( response.route_geometry );
|
||||||
|
if( OSRM.G.active_alternative >= response.alternative_geometries.length ) // no redraw if the selected alternative cannot be found
|
||||||
|
return;
|
||||||
|
positions = OSRM.RoutingGeometry._decode( response.alternative_geometries[ OSRM.G.active_alternative ], 5 );
|
||||||
OSRM.G.printwindow.OSRM.drawRoute( positions );
|
OSRM.G.printwindow.OSRM.drawRoute( positions );
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -57,6 +57,8 @@ timeoutRoute_Reversed: function() {
|
|||||||
showRoute: function(response, parameters) {
|
showRoute: function(response, parameters) {
|
||||||
if(!response)
|
if(!response)
|
||||||
return;
|
return;
|
||||||
|
if(!parameters || parameters.keepAlternative == false)
|
||||||
|
OSRM.G.active_alternative = 0;
|
||||||
|
|
||||||
OSRM.G.response = response; // needed for printing & history routes!
|
OSRM.G.response = response; // needed for printing & history routes!
|
||||||
if(response.status == 207) {
|
if(response.status == 207) {
|
||||||
@ -65,9 +67,10 @@ showRoute: function(response, parameters) {
|
|||||||
OSRM.RoutingDescription.showNA( OSRM.loc("NO_ROUTE_FOUND") );
|
OSRM.RoutingDescription.showNA( OSRM.loc("NO_ROUTE_FOUND") );
|
||||||
OSRM.Routing._snapRoute();
|
OSRM.Routing._snapRoute();
|
||||||
} else {
|
} else {
|
||||||
OSRM.RoutingGeometry.show(response);
|
OSRM.RoutingAlternatives.prepare(OSRM.G.response);
|
||||||
OSRM.RoutingNoNames.show(response);
|
OSRM.RoutingGeometry.show(OSRM.G.response);
|
||||||
OSRM.RoutingDescription.show(response);
|
OSRM.RoutingNoNames.show(OSRM.G.response);
|
||||||
|
OSRM.RoutingDescription.show(OSRM.G.response);
|
||||||
OSRM.Routing._snapRoute();
|
OSRM.Routing._snapRoute();
|
||||||
}
|
}
|
||||||
OSRM.Routing._updateHints(response);
|
OSRM.Routing._updateHints(response);
|
||||||
@ -95,14 +98,17 @@ showRoute_Dragging: function(response) {
|
|||||||
if(OSRM.G.pending)
|
if(OSRM.G.pending)
|
||||||
setTimeout(OSRM.Routing.draggingTimeout,1);
|
setTimeout(OSRM.Routing.draggingTimeout,1);
|
||||||
},
|
},
|
||||||
showRoute_Redraw: function(response) {
|
showRoute_Redraw: function(response, parameters) {
|
||||||
if(!response)
|
if(!response)
|
||||||
return;
|
return;
|
||||||
|
if(!parameters || parameters.keepAlternative == false)
|
||||||
|
OSRM.G.active_alternative = 0;
|
||||||
|
|
||||||
//OSRM.G.response = response; // not needed, even harmful as important information is not stored!
|
OSRM.G.response = response; // not needed, even harmful as important information is not stored! ==> really ????
|
||||||
if(response.status != 207) {
|
if(response.status != 207) {
|
||||||
OSRM.RoutingGeometry.show(response);
|
OSRM.RoutingAlternatives.prepare(OSRM.G.response);
|
||||||
OSRM.RoutingNoNames.show(response);
|
OSRM.RoutingGeometry.show(OSRM.G.response);
|
||||||
|
OSRM.RoutingNoNames.show(OSRM.G.response);
|
||||||
}
|
}
|
||||||
OSRM.Routing._updateHints(response);
|
OSRM.Routing._updateHints(response);
|
||||||
},
|
},
|
||||||
@ -132,13 +138,13 @@ getRoute_Reversed: function() {
|
|||||||
OSRM.JSONP.clear('route');
|
OSRM.JSONP.clear('route');
|
||||||
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&instructions=true', OSRM.Routing.showRoute, OSRM.Routing.timeoutRoute_Reversed, OSRM.DEFAULTS.JSONP_TIMEOUT, 'route');
|
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&instructions=true', OSRM.Routing.showRoute, OSRM.Routing.timeoutRoute_Reversed, OSRM.DEFAULTS.JSONP_TIMEOUT, 'route');
|
||||||
},
|
},
|
||||||
getRoute_Redraw: function() {
|
getRoute_Redraw: function(parameters) {
|
||||||
if( OSRM.G.markers.route.length < 2 )
|
if( OSRM.G.markers.route.length < 2 )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
OSRM.JSONP.clear('dragging');
|
OSRM.JSONP.clear('dragging');
|
||||||
OSRM.JSONP.clear('redraw');
|
OSRM.JSONP.clear('redraw');
|
||||||
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&instructions=true', OSRM.Routing.showRoute_Redraw, OSRM.Routing.timeoutRoute, OSRM.DEFAULTS.JSONP_TIMEOUT, 'redraw');
|
OSRM.JSONP.call(OSRM.Routing._buildCall()+'&instructions=true', OSRM.Routing.showRoute_Redraw, OSRM.Routing.timeoutRoute, OSRM.DEFAULTS.JSONP_TIMEOUT, 'redraw',parameters);
|
||||||
},
|
},
|
||||||
getRoute_Dragging: function() {
|
getRoute_Dragging: function() {
|
||||||
OSRM.G.pending = !OSRM.JSONP.call(OSRM.Routing._buildCall()+'&instructions=false', OSRM.Routing.showRoute_Dragging, OSRM.Routing.timeoutRoute_Dragging, OSRM.DEFAULTS.JSONP_TIMEOUT, 'dragging');;
|
OSRM.G.pending = !OSRM.JSONP.call(OSRM.Routing._buildCall()+'&instructions=false', OSRM.Routing.showRoute_Dragging, OSRM.Routing.timeoutRoute_Dragging, OSRM.DEFAULTS.JSONP_TIMEOUT, 'dragging');;
|
||||||
|
127
WebContent/routing/OSRM.RoutingAlternatives.js
Normal file
127
WebContent/routing/OSRM.RoutingAlternatives.js
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
/*
|
||||||
|
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 routing alternatives
|
||||||
|
// [everything about handling alternatives]
|
||||||
|
|
||||||
|
|
||||||
|
OSRM.RoutingAlternatives = {
|
||||||
|
|
||||||
|
// data of gui buttons for alternativess
|
||||||
|
_buttons: [
|
||||||
|
{id:"gui-a", label:"A"},
|
||||||
|
{id:"gui-b", label:"B"}
|
||||||
|
],
|
||||||
|
|
||||||
|
// initialize required values
|
||||||
|
init: function() {
|
||||||
|
OSRM.G.active_alternative = 0;
|
||||||
|
OSRM.G.alternative_count = 0;
|
||||||
|
},
|
||||||
|
|
||||||
|
// restructure response data
|
||||||
|
prepare: function(response) {
|
||||||
|
// move best route to alternative array
|
||||||
|
var the_response = OSRM.G.response;
|
||||||
|
the_response.alternative_geometries.unshift( response.route_geometry );
|
||||||
|
the_response.alternative_instructions.unshift( response.route_instructions );
|
||||||
|
the_response.alternative_summaries.unshift( response.route_summary );
|
||||||
|
|
||||||
|
// update basic information
|
||||||
|
OSRM.G.alternative_count = response.alternative_geometries.length;
|
||||||
|
if( OSRM.G.active_alternative >= OSRM.G.alternative_count ) // reset if the selected alternative cannot be found
|
||||||
|
OSRM.G.active_alternative = 0;
|
||||||
|
|
||||||
|
// switch data
|
||||||
|
the_response.route_geometry = the_response.alternative_geometries[OSRM.G.active_alternative];
|
||||||
|
the_response.route_instructions = the_response.alternative_instructions[OSRM.G.active_alternative];
|
||||||
|
the_response.route_summary = the_response.alternative_summaries[OSRM.G.active_alternative];
|
||||||
|
},
|
||||||
|
|
||||||
|
// switch active alternative and redraw buttons accordingly
|
||||||
|
setActive: function(button_id) {
|
||||||
|
// switch active alternative
|
||||||
|
OSRM.G.active_alternative = button_id;
|
||||||
|
|
||||||
|
// redraw clickable buttons
|
||||||
|
var buttons = OSRM.RoutingAlternatives._buttons;
|
||||||
|
for(var i=0, size=OSRM.G.alternative_count; i<size; i++) {
|
||||||
|
document.getElementById( buttons[i].id ).className = (button_id == i) ? "button-pressed top-right-button" : "button top-right-button";
|
||||||
|
}
|
||||||
|
// do nothing for non-clickable buttons
|
||||||
|
},
|
||||||
|
|
||||||
|
//draw GUI and register click events
|
||||||
|
show: function() {
|
||||||
|
var buttons = OSRM.RoutingAlternatives._buttons;
|
||||||
|
var data = "";
|
||||||
|
// draw clickable buttons
|
||||||
|
for(var i=0, size=OSRM.G.alternative_count; i<size; i++) {
|
||||||
|
var distance = OSRM.Utils.toHumanDistance(OSRM.G.response.alternative_summaries[i].total_distance);
|
||||||
|
var time = OSRM.Utils.toHumanTime(OSRM.G.response.alternative_summaries[i].total_time);
|
||||||
|
var tooltip = OSRM.loc("DISTANCE")+":"+distance+" "+OSRM.loc("DURATION")+":"+time;
|
||||||
|
var buttonClass = (i == OSRM.G.active_alternative) ? "button-pressed" : "button";
|
||||||
|
data = '<a class="'+buttonClass+' top-right-button" id="'+buttons[i].id+'" title="'+tooltip+'">'+buttons[i].label+'</a>' + data;
|
||||||
|
}
|
||||||
|
// draw non-clickable buttons
|
||||||
|
for(var i=OSRM.G.alternative_count, size=buttons.length; i<size; ++i) {
|
||||||
|
data = '<a class="button-inactive top-right-button" id="'+buttons[i].id+'">'+buttons[i].label+'</a>' + data;
|
||||||
|
}
|
||||||
|
// add buttons to DOM
|
||||||
|
document.getElementById('information-box-header').innerHTML = data + document.getElementById('information-box-header').innerHTML;
|
||||||
|
|
||||||
|
// add events
|
||||||
|
for(var i=0, size=OSRM.G.alternative_count; i<size; i++) {
|
||||||
|
document.getElementById(buttons[i].id).onclick = function (button_id) { return function() {OSRM.RoutingAlternatives._click(button_id); }; }(i) ;
|
||||||
|
document.getElementById(buttons[i].id).onmouseover = function (button_id) { return function() {OSRM.RoutingAlternatives._mouseover(button_id); }; } (i);
|
||||||
|
document.getElementById(buttons[i].id).onmouseout = function (button_id) { return function() {OSRM.RoutingAlternatives._mouseout(button_id); }; } (i);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
// mouse events on buttons
|
||||||
|
_click: function(button_id) {
|
||||||
|
if( OSRM.G.active_alternative == button_id )
|
||||||
|
return;
|
||||||
|
OSRM.RoutingAlternatives.setActive(button_id);
|
||||||
|
OSRM.G.route.hideAlternativeRoute();
|
||||||
|
|
||||||
|
// switch data
|
||||||
|
var the_response = OSRM.G.response;
|
||||||
|
the_response.route_geometry = the_response.alternative_geometries[button_id];
|
||||||
|
the_response.route_instructions = the_response.alternative_instructions[button_id];
|
||||||
|
the_response.route_summary = the_response.alternative_summaries[button_id];
|
||||||
|
|
||||||
|
// redraw route & data
|
||||||
|
OSRM.RoutingGeometry.show(the_response);
|
||||||
|
OSRM.RoutingNoNames.show(the_response);
|
||||||
|
OSRM.RoutingDescription.show(the_response);
|
||||||
|
},
|
||||||
|
_mouseover: function(button_id) {
|
||||||
|
if( OSRM.G.active_alternative == button_id )
|
||||||
|
return;
|
||||||
|
|
||||||
|
var geometry = OSRM.RoutingGeometry._decode( OSRM.G.response.alternative_geometries[button_id], 5);
|
||||||
|
OSRM.G.route.showAlternativeRoute(geometry);
|
||||||
|
},
|
||||||
|
_mouseout: function(button_id) {
|
||||||
|
if( OSRM.G.active_alternative == button_id )
|
||||||
|
return;
|
||||||
|
|
||||||
|
OSRM.G.route.hideAlternativeRoute();
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
@ -29,6 +29,7 @@ onClickRouteDescription: function(lat, lng) {
|
|||||||
},
|
},
|
||||||
onClickCreateShortcut: function(src){
|
onClickCreateShortcut: function(src){
|
||||||
src += '&z='+ OSRM.G.map.getZoom() + '¢er=' + OSRM.G.map.getCenter().lat.toFixed(6) + ',' + OSRM.G.map.getCenter().lng.toFixed(6);
|
src += '&z='+ OSRM.G.map.getZoom() + '¢er=' + OSRM.G.map.getCenter().lat.toFixed(6) + ',' + OSRM.G.map.getCenter().lng.toFixed(6);
|
||||||
|
src += '&alt='+OSRM.G.active_alternative;
|
||||||
src += '&df=' + OSRM.G.DISTANCE_FORMAT;
|
src += '&df=' + OSRM.G.DISTANCE_FORMAT;
|
||||||
|
|
||||||
var source = OSRM.DEFAULTS.SHORTENER_PARAMETERS.replace(/%url/, OSRM.DEFAULTS.HOST_SHORTENER_URL+src);
|
var source = OSRM.DEFAULTS.SHORTENER_PARAMETERS.replace(/%url/, OSRM.DEFAULTS.HOST_SHORTENER_URL+src);
|
||||||
@ -100,11 +101,14 @@ show: function(response) {
|
|||||||
body += '</table>';
|
body += '</table>';
|
||||||
|
|
||||||
// build header
|
// build header
|
||||||
header = OSRM.RoutingDescription._buildHeader(OSRM.Utils.toHumanDistance(response.route_summary.total_distance), OSRM.Utils.toHumanTime(response.route_summary.total_time), route_link, gpx_link);
|
header = OSRM.RoutingDescription._buildHeader(OSRM.Utils.toHumanDistance(response.route_summary.total_distance), OSRM.Utils.toHumanTime(response.route_summary.total_time), route_link, gpx_link);
|
||||||
|
|
||||||
// update DOM
|
// update DOM
|
||||||
document.getElementById('information-box-header').innerHTML = header;
|
document.getElementById('information-box-header').innerHTML = header;
|
||||||
document.getElementById('information-box').innerHTML = body;
|
document.getElementById('information-box').innerHTML = body;
|
||||||
|
|
||||||
|
// add alternative GUI (has to be done last since DOM has to be updated before events are registered)
|
||||||
|
OSRM.RoutingAlternatives.show();
|
||||||
},
|
},
|
||||||
|
|
||||||
// simple description
|
// simple description
|
||||||
|
@ -30,12 +30,9 @@ toHumanTime: function(seconds){
|
|||||||
seconds = seconds%60;
|
seconds = seconds%60;
|
||||||
hours = parseInt(minutes/60);
|
hours = parseInt(minutes/60);
|
||||||
minutes = minutes%60;
|
minutes = minutes%60;
|
||||||
if(hours==0){
|
if(hours==0 && minutes==0){ return seconds + ' ' + 's'; }
|
||||||
return minutes + ' ' + 'min';
|
else if(hours==0){ return minutes + ' ' + 'min'; }
|
||||||
}
|
else{ return hours + ' ' + 'h' + ' ' + minutes + ' ' + 'min';}
|
||||||
else{
|
|
||||||
return hours + ' ' + 'h' + ' ' + minutes + ' ' + 'min';
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
//human readable distance
|
//human readable distance
|
||||||
setToHumanDistanceFunction: function(type) {
|
setToHumanDistanceFunction: function(type) {
|
||||||
|
Loading…
Reference in New Issue
Block a user