我怎样才能得到两个点之间的距离经纬度? [英] How can I get the distance between two point by latlng?

查看:235
本文介绍了我怎样才能得到两个点之间的距离经纬度?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想从一个我跑我用下面的code程序的距离甲乙经latlng.When,它返回一个错误的结果。 FX我trye​​d A(31.172740,115.0081630),则B(30.6055980,114.3603140),其结果是关于3111km.but合适的距离大约是134公里。 我的code是:

 类btnListener实现OnClickListener {

    公共无效的onClick(视图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()。
         双A1中,n1,A2,N2;
         A1 = 30.6055980;
         A2 = Double.parseDouble(lat_b);
         N2 = Double.parseDouble(lng_b);
         双R = 6371;
         双D = Math.acos(Math.sin(a1)中* Math.sin(A2)+ Math.cos(a1)中* Math.cos(a2)的* Math.cos(N2-N1));
         Toast.makeText(getApplication(),距离+将String.valueOf(D * R)+从公里B,Toast.LENGTH_SHORT).show();
    }

}
 

解决方案

尝试下面code。

 公众持股量的距离(浮动lat_a,浮lng_a,浮lat_b,浮动lng_b)
{
    双earthRadius = 3958.75;
    双latDiff = Math.toRadians(lat_b-lat_a);
    双lngDiff = Math.toRadians(lng_b-lng_a);
    双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);
    双c = 2 * Math.atan2(的Math.sqrt(a)中,的Math.sqrt(1-a))的;
    双距离= earthRadius * C;

    INT meterConversion = 1609;

    返回新的浮动(距离* meterConversion).floatValue();
}
 

如果你不明白,请检查此链接,同一code,适用在这里。

I want to get the distance from A to B by latlng.When i run my app with the following code,it return a wrong result. Fx i tryed A( 31.172740,115.0081630) ,then B(30.6055980,114.3603140),the result is about 3111km.but the right distance is about 134km. My code is:

    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();
    }

}

解决方案

Try below code.

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();
}

If you didn't understood, please check this link, same code available here.

这篇关于我怎样才能得到两个点之间的距离经纬度?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆