X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5401055ce16a7bd74dd0dc2a0caf2dbc66e0d986..9f7ec064e448a745e0ea2615a089f0988215dec6:/app/assets/javascripts/index/directions/graphhopper.js?ds=sidebyside diff --git a/app/assets/javascripts/index/directions/graphhopper.js b/app/assets/javascripts/index/directions/graphhopper.js index 71161c591..6bd430c06 100644 --- a/app/assets/javascripts/index/directions/graphhopper.js +++ b/app/assets/javascripts/index/directions/graphhopper.js @@ -3,39 +3,40 @@ function GraphHopperEngine(id, vehicleType) { "-3": 7, // sharp left "-2": 6, // left "-1": 5, // slight left - 0: 0, // straight - 1: 1, // slight right - 2: 2, // right - 3: 3, // sharp right - 4: 14, // finish reached - 5: 14, // via reached - 6: 10 // roundabout + "0": 0, // straight + "1": 1, // slight right + "2": 2, // right + "3": 3, // sharp right + "4": 14, // finish reached + "5": 14, // via reached + "6": 10 // roundabout }; return { id: id, - creditline: 'Graphhopper', + creditline: "Graphhopper", draggable: false, getRoute: function (points, callback) { // GraphHopper Directions API documentation - // https://github.com/graphhopper/directions-api/blob/master/docs-routing.md + // https://graphhopper.com/api/1/docs/routing/ return $.ajax({ - url: document.location.protocol + OSM.GRAPHHOPPER_URL, + url: OSM.GRAPHHOPPER_URL, data: { - vehicle: vehicleType, - locale: I18n.currentLocale(), - key: "LijBPDQGfu7Iiq80w3HzwB4RUDJbMbhs6BU0dEnn", - type: "jsonp", - elevation: false, - instructions: true, - point: points.map(function (p) { return p.lat + "," + p.lng; }) + "vehicle": vehicleType, + "locale": I18n.currentLocale(), + "key": "LijBPDQGfu7Iiq80w3HzwB4RUDJbMbhs6BU0dEnn", + "ch.disable": vehicleType === "car", + "elevation": false, + "instructions": true, + "point": points.map(function (p) { return p.lat + "," + p.lng; }) }, traditional: true, - dataType: "jsonp", + dataType: "json", success: function (data) { - if (!data.paths || data.paths.length === 0) + if (!data.paths || data.paths.length === 0) { return callback(true); + } var path = data.paths[0]; var line = L.PolylineUtil.decode(path.points); @@ -49,12 +50,16 @@ function GraphHopperEngine(id, vehicleType) { instrText += instr.text; var latLng = line[instr.interval[0]]; var distInMeter = instr.distance; + var lineseg = []; + for (var j = instr.interval[0]; j <= instr.interval[1]; j++) { + lineseg.push({ lat: line[j][0], lng: line[j][1] }); + } steps.push([ - {lat: latLng.lat, lng: latLng.lng}, + { lat: latLng[0], lng: latLng[1] }, instrCode, instrText, distInMeter, - [] + lineseg ]); // TODO does graphhopper map instructions onto line indices? } @@ -75,5 +80,6 @@ function GraphHopperEngine(id, vehicleType) { }; } +OSM.Directions.addEngine(new GraphHopperEngine("graphhopper_car", "car"), true); OSM.Directions.addEngine(new GraphHopperEngine("graphhopper_bicycle", "bike"), true); OSM.Directions.addEngine(new GraphHopperEngine("graphhopper_foot", "foot"), true);