谷歌地图 - 如何获得米之间的两点之间的距离?
我有这些坐标:谷歌地图 - 如何获得米之间的两点之间的距离?
(45.463688, 9.18814)
(46.0438317, 9.75936230000002)
,我需要(trought谷歌API V3,我认为),以获得在这些米2点之间的距离。我该怎么做?
如果你正在寻找使用v3的谷歌地图API,这里是一个功能的使用方法: 注意:您必须添加&libraries=geometry
到脚本源
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false&libraries=geometry"></script>
<script>
var p1 = new google.maps.LatLng(45.463688, 9.18814);
var p2 = new google.maps.LatLng(46.0438317, 9.75936230000002);
alert(calcDistance(p1, p2));
//calculates distance between two points in km's
function calcDistance(p1, p2) {
return (google.maps.geometry.spherical.computeDistanceBetween(p1, p2)/1000).toFixed(2);
}
</script>
我认为你可以没有任何特定的API做的,用简单的Javascript计算距离:
This网站有关于地理计算和JavaScript样本距离计算的很好的信息。
好吧,在谷歌API网页快速浏览一下,似乎,你可以通过做:
- 呼叫为DirectionsService()路线(),以获得DirectionsResult与路线
- 对于一个或每个路由走通过它的腿特性,算出距离
这主要与数学做谷歌的API之外,所以你不应该需要使用API比找到正确的坐标以外的任何其他的总和。
知道了,这里有一个链接到一个以前回答与Javascript有关的问题。
试试这个
CLLocationCoordinate2D coord1;
coord1.latitude = 45.463688;
coord1.longitude = 9.18814;
CLLocation *loc1 = [[[CLLocation alloc] initWithLatitude:coord1.latitude longitude:coord1.longitude] autorelease];
CLLocationCoordinate2D coord2;
coord2.latitude = 46.0438317;
coord2.longitude = 9.75936230000002;
CLLocation *loc2 = [[[CLLocation alloc] initWithLatitude:46.0438317 longitude:9.75936230000002] autorelease];
CLLocationDistance d1 = [loc1 distanceFromLocation:loc2];
如何获得2点之间的路线距离,这只是给出了直接距离(在物理学文献中:位移),如何获得路径距离 –
这就是目标C :)问题是关于Javascript API谷歌地图 –
请提供解释,而不是“试试这个”。 –
试试这个:
const const toRadians = (val) => {
return val * Math.PI/180;
}
const toDegrees = (val) => {
return val * 180/Math.PI;
}
// Calculate a point winthin a circle
// circle ={center:LatLong, radius: number} // in metres
const pointInsideCircle = (point, circle) => {
let center = circle.center;
let distance = distanceBetween(point, center);
//alert(distance);
return distance < circle.radius;
};
const distanceBetween = (point1, point2) => {
//debugger;
var R = 6371e3; // metres
var φ1 = toRadians(point1.latitude);
var φ2 = toRadians(point2.latitude);
var Δφ = toRadians(point2.latitude - point1.latitude);
var Δλ = toRadians(point2.longitude - point1.longitude);
var a = Math.sin(Δφ/2) * Math.sin(Δφ/2) +
Math.cos(φ1) * Math.cos(φ2) *
Math.sin(Δλ/2) * Math.sin(Δλ/2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
return R * c;
}
请改善您的答案。为什么它更好,它是如何工作的等等。“试试这个”是不够的。 *不是关于盲目尝试,而是阅读和理解事物的工作方式。还是谢谢你的贡献:) –
如果您使用距离矩阵api来计算距离和行程时间,则可以使用距离矩阵api。 – commando24