如何通过latlng获得两点之间的距离?

问题描述:

我想通过latlng获得从A到B的距离。当我使用下面的代码运行我的应用程序时,它返回错误的结果。 我试了A(31.172740,115.0081630),然后B(30.6055980,114.3603140),结果是3111km左右,但是右边的距离大概是134km。 我的代码是:如何通过latlng获得两点之间的距离?

class btnListener implements OnClickListener{ 

    public void onClick(View v) { 
     lat_a=lat_A.getText().toString(); 
     lng_a=lng_A.getText().toString(); 
     lat_b=lat_B.getText().toString(); 
     lng_b=lng_B.getText().toString(); 
     double a1,n1,a2,n2; 
     a1=30.6055980; 
     a2=Double.parseDouble(lat_b); 
     n2=Double.parseDouble(lng_b); 
     double R=6371; 
     double D=Math.acos(Math.sin(a1)*Math.sin(a2)+Math.cos(a1)*Math.cos(a2)*Math.cos(n2-n1)); 
     Toast.makeText(getApplication(), "the distance is"+String.valueOf(D*R)+"km from A to B", Toast.LENGTH_SHORT).show(); 
    } 

} 
+0

看看 http://*.com/questions/2741403/get-the-distance-between-two-geo-points – Saasha 2012-01-12 08:46:29

+0

许多thanks.i我发现它。 – lanyimo 2012-01-12 08:58:07

请尝试以下代码。

public float distance (float lat_a, float lng_a, float lat_b, float lng_b) 
{ 
    double earthRadius = 3958.75; 
    double latDiff = Math.toRadians(lat_b-lat_a); 
    double lngDiff = Math.toRadians(lng_b-lng_a); 
    double a = Math.sin(latDiff /2) * Math.sin(latDiff /2) + 
    Math.cos(Math.toRadians(lat_a)) * Math.cos(Math.toRadians(lat_b)) * 
    Math.sin(lngDiff /2) * Math.sin(lngDiff /2); 
    double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
    double distance = earthRadius * c; 

    int meterConversion = 1609; 

    return new Float(distance * meterConversion).floatValue(); 
} 

如果你不明白,please check this link,相同的代码在这里可用。

+0

谢谢。让我们尝试一下。 – lanyimo 2012-01-12 08:57:18

有由Android本身提供了两个点之间的距离获得的API。使用:

Location.distanceBetween(
    startLatitude, 
    startLongitude, 
    endLatitude, 
    endLongitude, 
    results); 

它以米为单位返回距离。

+0

我发现结果是与一种浮动arry。我再试一次。谢谢。 – lanyimo 2012-01-12 08:49:24

+10

值得一提的是,以米为单位的距离存储在结果[0]中。更多信息:http://developer.android.com/reference/android/location/Location.html#distanceBetween(double,%20double,%20double,%20double,%20float []) – cyborg86pl 2014-10-09 22:40:28

+1

计算出的距离存储在结果[ 0]。如果结果长度大于或等于2,则初始方位将存储在结果[1]中。如果结果长度为3或更大,则最终方位将存储在结果[2]中。 – 2017-10-31 15:35:23