为了账号安全,请及时绑定邮箱和手机立即绑定

计算两个GPS坐标之间的距离

计算两个GPS坐标之间的距离

富国沪深 2019-06-14 17:18:31
计算两个GPS坐标之间的距离如何计算两个GPS坐标之间的距离(使用纬度和经度)?
查看完整描述

3 回答

?
繁星coding

TA贡献1797条经验 获得超4个赞

用经纬度计算两个坐标之间的距离,包括Javascript实现。

西地点是阴性的。记住,分秒是60秒,所以S31 30‘是-31.50度。

别忘了将度转换为弧度..许多语言都有这个功能。或者这是一个简单的计算:radians = degrees * PI / 180.

function degreesToRadians(degrees) {
  return degrees * Math.PI / 180;
}

function distanceInKmBetweenEarthCoordinates(lat1, lon1, lat2, lon2) {
  var earthRadiusKm = 6371;

  var dLat = degreesToRadians(lat2-lat1);
  var dLon = degreesToRadians(lon2-lon1);

  lat1 = degreesToRadians(lat1);
  lat2 = degreesToRadians(lat2);

  var a = Math.sin(dLat/2) * Math.sin(dLat/2) +
          Math.sin(dLon/2) * Math.sin(dLon/2) * Math.cos(lat1) * Math.cos(lat2); 
  var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
  return earthRadiusKm * c;
}

下面是一些用法示例:

相同点之间的距离(0,0,0,0)/应为0 0距离(51.5,0,38.8,-77.1)/从伦敦到阿灵顿5918.185064088764

查看完整回答
反对 回复 2019-06-14
?
动漫人物

TA贡献1815条经验 获得超10个赞

使用Google寻找haversine;以下是我的解决方案:

#include <math.h>
#include "haversine.h"

#define d2r (M_PI / 180.0)

//calculate haversine distance for linear distance
double haversine_km(double lat1, double long1, double lat2, double long2)
{
    double dlong = (long2 - long1) * d2r;
    double dlat = (lat2 - lat1) * d2r;
    double a = pow(sin(dlat/2.0), 2) + cos(lat1*d2r) * cos(lat2*d2r) * pow(sin(dlong/2.0), 2);
    double c = 2 * atan2(sqrt(a), sqrt(1-a));
    double d = 6367 * c;

    return d;
}

double haversine_mi(double lat1, double long1, double lat2, double long2)
{
    double dlong = (long2 - long1) * d2r;
    double dlat = (lat2 - lat1) * d2r;
    double a = pow(sin(dlat/2.0), 2) + cos(lat1*d2r) * cos(lat2*d2r) * pow(sin(dlong/2.0), 2);
    double c = 2 * atan2(sqrt(a), sqrt(1-a));
    double d = 3956 * c; 

    return d;
}


查看完整回答
反对 回复 2019-06-14
  • 3 回答
  • 0 关注
  • 1950 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信