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

前端之家收集整理的这篇文章主要介绍了android – 如何通过latlng获得两点之间的距离?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想通过latlng从A到B的距离.当我运行我的应用程序与以下代码,它返回一个错误的结果.
Fx我试过A(31.172740,115.0081630),然后B(30.6055980,114.3603140),结果是约3111km,但距离约134km.
我的代码是:
  1. class btnListener implements OnClickListener{
  2.  
  3. public void onClick(View v) {
  4. lat_a=lat_A.getText().toString();
  5. lng_a=lng_A.getText().toString();
  6. lat_b=lat_B.getText().toString();
  7. lng_b=lng_B.getText().toString();
  8. double a1,n1,a2,n2;
  9. a1=30.6055980;
  10. a2=Double.parseDouble(lat_b);
  11. n2=Double.parseDouble(lng_b);
  12. double R=6371;
  13. double D=Math.acos(Math.sin(a1)*Math.sin(a2)+Math.cos(a1)*Math.cos(a2)*Math.cos(n2-n1));
  14. Toast.makeText(getApplication(),"the distance is"+String.valueOf(D*R)+"km from A to B",Toast.LENGTH_SHORT).show();
  15. }
  16.  
  17. }

解决方法

请尝试下面的代码.
  1. public float distance (float lat_a,float lng_a,float lat_b,float lng_b )
  2. {
  3. double earthRadius = 3958.75;
  4. double latDiff = Math.toRadians(lat_b-lat_a);
  5. double lngDiff = Math.toRadians(lng_b-lng_a);
  6. double a = Math.sin(latDiff /2) * Math.sin(latDiff /2) +
  7. Math.cos(Math.toRadians(lat_a)) * Math.cos(Math.toRadians(lat_b)) *
  8. Math.sin(lngDiff /2) * Math.sin(lngDiff /2);
  9. double c = 2 * Math.atan2(Math.sqrt(a),Math.sqrt(1-a));
  10. double distance = earthRadius * c;
  11.  
  12. int meterConversion = 1609;
  13.  
  14. return new Float(distance * meterConversion).floatValue();
  15. }

如果你没有理解,please check this link,这里提供相同的代码.

猜你在找的Android相关文章