반응형
자바에서 경도와 위도를 알고있을 때 미터 단위로 거리 계산
가능성 가능성 :
Java에서 위도 / 경도 값 작업
복제 :
두 좌표로 주어진 두 점 사이의 거리를 계산해야합니다. 내가 작업중 인 프로젝트는 Java 프로젝트 자바 코드는 훌륭하지만 의사 코드도 제공 할 수 있으며 직접 구현할 수 있습니다. :)
아시다시피 좌표를 세 가지 방법이 있습니다.
- 도 : 분 : 초 (49 ° 30'00 "N, 123 ° 30'00"W)
- 도 : 10 진수 분 (49 ° 30.0 ', -123 ° 30.0'), (49d30.0m, -123d30.0 ')
- 10 진수도 (49.5000 °, -123.5000 °), 일반적으로 4 ~ 6 개의 10 진수.
내 좌표를 제공하는 세 번째 방법이 값에 대한 코드가 선호됩니다. :)
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;
}
GPS 용 Java Geodesy Library를 사용할 수 있으며 지구 표면 곡률을 고려한 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
결과 거리는 미터 단위입니다.
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;
}
반응형
'ProgramingTip' 카테고리의 다른 글
Android- 회전시 WebView 다시로드 방지 (0) | 2020.10.20 |
---|---|
MongoDb가 코드 100으로 종료 됨 (0) | 2020.10.20 |
Unix : 파일에 파일을 삭제하는 방법 (0) | 2020.10.20 |
Html.TextBoxFor에 대한 조건에 따라 속성 설정 (0) | 2020.10.20 |
JS 객체에 키가 있는지 확인 (0) | 2020.10.20 |