js根据经纬度计算两地之间的距离
时间: 2023-11-06 21:05:59 浏览: 103
实现方式:
1. 将经纬度转换为弧度
2. 根据经纬度计算两点之间的距离公式(Haversine formula)
代码实现:
```javascript
function getDistance(lat1, lon1, lat2, lon2) {
const R = 6371; // 地球半径,单位为千米
const dLat = (lat2 - lat1) * Math.PI / 180; // 转换为弧度
const dLon = (lon2 - lon1) * Math.PI / 180;
const a =
Math.sin(dLat / 2) * Math.sin(dLat / 2) +
Math.cos(lat1 * Math.PI / 180) * Math.cos(lat2 * Math.PI / 180) *
Math.sin(dLon / 2) * Math.sin(dLon / 2);
const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
const distance = R * c; // 单位为千米
return distance;
}
```
使用示例:
```javascript
const lat1 = 31.2304;
const lon1 = 121.4737;
const lat2 = 39.9042;
const lon2 = 116.4074;
const distance = getDistance(lat1, lon1, lat2, lon2);
console.log(distance); // 输出结果为:1060.62 单位为千米
```
注意事项:
1. 经度为正数表示东经,负数表示西经;纬度为正数表示北纬,负数表示南纬;
2. 需要注意经纬度的单位,上述代码中使用的是度数,需要将其转换为弧度;
3. 地球的半径不是一个精确的常数,不同的计算方法和测量方法会得到略有不同的结果。
阅读全文