利用谷歌地图API获取点与点的距离的js代码
2018-10-12 14:04
585 查看
var request;
var distanceArray = [];
function getdistance() {
distanceArray = [];
var directionsService = new google.maps.DirectionsService();
for (var a = 0; a < pointsArray.length; a++) {
for (var b = 0; b < pointsArray.length; b++) {
if (a != b) {
request = null;
request = {
origin: pointsArray[a],
destination: pointsArray[b],
travelMode: google.maps.DirectionsTravelMode.DRIVING,
unitSystem: google.maps.DirectionsUnitSystem.METRIC
};
directionsService.route(request, function (response, status) {
if (status == google.maps.DirectionsStatus.OK) {
var myRoute = response.routes[0].legs[0].distance.value; //路线长度
distanceArray.push(myRoute);
}
});
}
}
}
}
有一个问题想与大家交流一下,利用谷歌地图API获取批量的点点之间的距离时,如何保证自己得到的距离信息是有序的?
比如:有pointsArray[]中有a,b,c三个点的数据,我怎么才能按序得到[a,b],[a,c],[b,a],[b,c],[c,a],[c,b]的距离信息。
在上面的代码中,所有a!=b的距离都是一次性传给directionsService.route进行求解的,也就是说,外围的FOR循环控制对其没有用。所以想依靠FOR循环一个一个按序获得距离的期望失败了。但是如果在其中加入调试,一步一步控制其循环求解的过程,却能得出有序距离数组。不得其解啊!
您可能感兴趣的文章:
相关文章推荐
- 手机终端设备启动微信app客户端的JS实现代码------利用JS获取url参数值
- 利用谷歌地图API获取点与点的距离的js代码
- 利用js 获取本日 本周 本月时间代码
- 利用谷歌地图API获取点与点的距离
- 利用js实现前台动态添加文本框,后台获取文本框内容(示例代码)
- 利用js获取浏览器高度和宽度值(多浏览器)代码大全
- [转载]js/jquery获取浏览器窗口可视区域高度和宽度以及滚动条高度实现代码
- js获取单元格自定义属性值的代码(IE/Firefox)
- 利用Google Api计算行车距离代码
- js获取字符串最后一个字符代码
- js获取字符串最后一个字符代码
- 获取offsetTop和offsetLeft值的js代码(兼容)
- 如何利用JS实现对后台CS代码的调用
- js获取某元素的class里面的css属性值代码(转)
- JS获取图片/图像文件大小的代码
- js获取浏览器的可视区域尺寸的实现代码
- 利用js获取服务器时间的两个简单方法
- PHP 利用AJAX获取网页并输出的实现代码(Zjmainstay)