亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

計算兩個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 關注
  • 2001 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號