77

重複の可能性:
Javaでの緯度/経度の値の操作

複製:

2つの座標で与えられる2点間の距離を計算する必要があります。私が取り組んでいるプロジェクトはJavaプロジェクトなので、Javaコードは素晴らしいですが、擬似コードを指定することもでき、それを自分で実装することもできます:)

ご存知かもしれませんが、座標を表すには3つの方法があります。

  • 度:分:秒(49°30'00 "N、123°30'00" W)
  • 度:小数分(49°30.0'、-123°30.0')、(49d30.0m、-123d30.0')
  • 10進角(49.5000°、-123.5000°)、通常は4〜6の10進数。

これは私の座標が与えられる3番目の方法なので、この値のコードが優先されます:)

4

3 に答える 3

192

stackoverflowに関する別の質問に基づいて、このコードを取得しました。これにより、マイルではなくメートルで結果が計算されます:)

 public static float distFrom(float lat1, float lng1, float lat2, float lng2) {
    double earthRadius = 6371000; //meters
    double dLat = Math.toRadians(lat2-lat1);
    double dLng = Math.toRadians(lng2-lng1);
    double a = Math.sin(dLat/2) * Math.sin(dLat/2) +
               Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) *
               Math.sin(dLng/2) * Math.sin(dLng/2);
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
    float dist = (float) (earthRadius * c);

    return dist;
    }
于 2009-05-08T02:11:22.140 に答える
27

GPS用のJavaGeodesyLibraryを使用できます。これは、地表の曲率を考慮したVincentyの式を使用します。

実装は次のようになります。

import org.gavaghan.geodesy.*;

...

GeodeticCalculator geoCalc = new GeodeticCalculator();

Ellipsoid reference = Ellipsoid.WGS84;  

GlobalPosition pointA = new GlobalPosition(latitude, longitude, 0.0); // Point A

GlobalPosition userPos = new GlobalPosition(userLat, userLon, 0.0); // Point B

double distance = geoCalc.calculateGeodeticCurve(reference, userPos, pointA).getEllipsoidalDistance(); // Distance between Point A and Point B

結果の距離はメートル単位です。

于 2011-12-12T01:26:15.973 に答える
4

C ++では、次のように実行されます。

#define LOCAL_PI 3.1415926535897932385 

double ToRadians(double degrees) 
{
  double radians = degrees * LOCAL_PI / 180;
  return radians;
}

double DirectDistance(double lat1, double lng1, double lat2, double lng2) 
{
  double earthRadius = 3958.75;
  double dLat = ToRadians(lat2-lat1);
  double dLng = ToRadians(lng2-lng1);
  double a = sin(dLat/2) * sin(dLat/2) + 
             cos(ToRadians(lat1)) * cos(ToRadians(lat2)) * 
             sin(dLng/2) * sin(dLng/2);
  double c = 2 * atan2(sqrt(a), sqrt(1-a));
  double dist = earthRadius * c;
  double meterConversion = 1609.00;
  return dist * meterConversion;
}
于 2009-12-10T13:58:54.930 に答える