• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
我是张洪铭我是熊博士
时光静好,与君同;细水长流,与君语
博客园    首页    新随笔    联系   管理    订阅  订阅

计算GPS点之间的距离

latitude纬度  longtitude经度
// 求弧度
double getRadian(double d)
{
    return d * PI / 180.0;   //角度1? = π / 180
}

//计算距离  米
double getDistance(double lat1, double lng1, double lat2, double lng2)
{
    double radLat1 = getRadian(lat1);
    double radLat2 = getRadian(lat2);
    double a = radLat1 - radLat2;
    double b = getRadian(lng1) - getRadian(lng2);

    double dst = 2 * asin((sqrt(pow(sin(a / 2), 2) + cos(radLat1) * cos(radLat2) * pow(sin(b / 2), 2) )));
    dst = dst * EARTH_RADIUS * 1000;

    return dst;
}

 

posted @ 2019-06-14 10:44  我是张洪铭我是熊博士  阅读(2119)  评论(1)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3