-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathmapmatching.js
More file actions
116 lines (103 loc) · 3.15 KB
/
mapmatching.js
File metadata and controls
116 lines (103 loc) · 3.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
* create an map array for this js
* */
var apiKey = 'AIzaSyAZEyaeSOnH8dcVq646GIyUQbxGKHza_dc';
var polylines = [];
var snappedCoordinates = [];
// path is a MVCArray
function initialize(order,path) {
runSnapToRoad(order,path);
}
// Snap a user-created polyline to roads and draw the snapped path
function runSnapToRoad(order,path) {
var center = {lat:-37.799604, lng:144.957807};
snappedCoordinates = [];
if(path.getLength()>100){
var route = breakLongPath(path);
for(var i=0;i<route.length;i++) {
requestSnap(order,snappedCoordinates,route[i]);
}
}
else{
requestSnap(order,snappedCoordinates,path);
}
}
//send snap-to-road request and handle callback
function requestSnap(order,snappedCoordinates,path){
var pathValues = [];
for (var i = 0; i < path.getLength(); i++) {
pathValues.push(path.getAt(i).toUrlValue());
}
$.get('https://roads.googleapis.com/v1/snapToRoads', {
interpolate: true,
key: apiKey,
path: pathValues.join('|')
}, function(data) {
//store response in local
processSnapToRoadResponse(order,snappedCoordinates,data);
});
}
// Store snapped polyline returned by the snap-to-road method.
function processSnapToRoadResponse(order,snappedCoordinates,data) {
for (var i = 0; i < data.snappedPoints.length; i++) {
var latlng = new google.maps.LatLng(
data.snappedPoints[i].location.latitude,
data.snappedPoints[i].location.longitude);
snappedCoordinates.push(latlng);
}
}
// Draws the snapped polyline (after processing snap-to-road response).
function drawSnappedPolyline(order,snappedCoordinates) {
addMap(centre,order);
var snappedPolyline = new google.maps.Polyline({
path: snappedCoordinates,
strokeColor: 'black',
strokeWeight: 3
});
//draw snapped points
for(var i=0;i<snappedCoordinates.length;i+=10){
addPoint(order,snappedCoordinates[i],i+1);
}
//draw snapped polyline
snappedPolyline.setMap(maps[order]);
polylines.push(snappedPolyline);
}
function addPoint(order,latlng,i){
new google.maps.Marker({
position: latlng,
map: maps[order],
label: i.toString(),
});
}
function breakLongPath(path){
var i = 1;
var segment = [];
var route = [];
while(path.getLength()>100*i){
i++;
}
var index =0;
for(var j=0; j<i; j++){
if(j==i-1){
segment.length = path.length-100*i+100;
}
var k = 0;
while(index<(j+1)*100&&index<path.length){
segment[k]=path.getAt(index);
k++;
index++;
}
route[j]=new google.maps.MVCArray(segment.slice());
}
return route;
}
//create a map element
function addMap(center,order){
$("#map").remove();
$("#map-container").prepend("<div class='col-sm-4'><div class='floating-title'>Test "+order+"</div><div class='map' id='map" + order+1 +"'></div></div>");
maps[order] = new google.maps.Map(document.getElementById('map'+order), {
zoom: 15,
center: center,
//mapTypeId: google.maps.MapTypeId.TERRAIN
});
}