>  기사  >  Java  >  위도와 경도를 사용하여 두 점 사이의 거리를 계산하는 방법은 무엇입니까?

위도와 경도를 사용하여 두 점 사이의 거리를 계산하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-31 13:09:041029검색

How to Calculate the Distance Between Two Points Using Latitude and Longitude?

위도와 경도를 이용하여 두 지점 사이의 거리를 계산

지도에서 두 지점 사이의 거리를 구하는 것은 다양한 분야에서 흔히 발생하는 작업입니다. 내비게이션부터 GIS까지. 이 거리를 정확하게 계산하는 한 가지 방법은 위도 및 경도 좌표 작업을 위해 특별히 설계된 Haversine 공식을 사용하는 것입니다.

Java에서 Haversine 공식 구현

A Java에서 Haversine 공식의 정확한 구현은 다음과 같습니다.

<code class="java">public static double distance(double lat1, double lon1, double lat2, double lon2) {
    final int R = 6371; // Radius of the earth in kilometers
    
    double latDistance = Math.toRadians(lat2 - lat1);
    double lonDistance = Math.toRadians(lon2 - lon1);
    double a = Math.sin(latDistance / 2) * Math.sin(latDistance / 2)
            + Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2))
            * Math.sin(lonDistance / 2) * Math.sin(lonDistance / 2);
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
    double distance = R * c * 1000; // convert to meters
    
    return distance;
}</code>

공식 사용

좌표(lat1, lon1)를 사용하여 두 점 사이의 거리를 계산하려면 ) 및 (lat2, lon2)는 이러한 값을 거리 메서드에 매개변수로 전달하기만 하면 됩니다. 결과는 미터 단위로 반환됩니다.

예:

<code class="java">double lat1 = 41.881832;
double lon1 = -87.623177;
double lat2 = 41.889809;
double lon2 = -87.621882;

double distance = distance(lat1, lon1, lat2, lon2);
System.out.println("Distance between the points: " + distance + " meters");</code>

정확도 고려 사항

결과의 정밀도 입력 좌표의 정확도에 따라 달라집니다. 위도 및 경도 값이 올바른 형식과 적절한 단위(예: 십진수 도)로 제공되는지 확인하는 것이 중요합니다.

위 내용은 위도와 경도를 사용하여 두 점 사이의 거리를 계산하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.