计算两对坐标之间的距离(纬度/经度)可以使用地球表面上的两点之间的大圆距离公式,也称为Haversine公式。该公式基于球面三角学,可以计算出两个坐标点之间的直线距离。
以下是计算两对坐标之间距离的步骤:
下面是一个示例代码,使用JavaScript语言计算两个坐标点之间的距离(单位为千米):
function calculateDistance(lat1, lon1, lat2, lon2) {
const earthRadius = 6371; // 地球半径(千米)
const toRadians = (degrees) => {
return degrees * Math.PI / 180;
};
const deltaLat = toRadians(lat2 - lat1);
const deltaLon = toRadians(lon2 - lon1);
const a = Math.sin(deltaLat / 2) * Math.sin(deltaLat / 2) +
Math.cos(toRadians(lat1)) * Math.cos(toRadians(lat2)) *
Math.sin(deltaLon / 2) * Math.sin(deltaLon / 2);
const c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
const distance = earthRadius * c;
return distance;
}
// 示例使用
const distance = calculateDistance(40.7128, -74.0060, 34.0522, -118.2437);
console.log(distance); // 输出结果:3938.3893795639725
这段代码使用了JavaScript语言,通过传入四个参数(两个坐标点的纬度和经度)来计算两个坐标点之间的距离。最后的结果以千米为单位。
腾讯云相关产品和产品介绍链接地址:
领取专属 10元无门槛券
手把手带您无忧上云