CountDistance.java 968 B

1234567891011121314151617181920212223242526272829303132
  1. package com.yihu.jw.utils;
  2. public class CountDistance {
  3. private static double EARTH_RADIUS = 6378.137;// 6378.137赤道半径6378137
  4. private static double rad(double d) {
  5. return d * Math.PI / 180.0;
  6. }
  7. /**
  8. * 通过经纬度计算两点之间的距离(单位:米)
  9. * @param latone
  10. * @param lngone
  11. * @param lattwo
  12. * @param lngtwo
  13. * @return
  14. */
  15. public double getDistance(double latone, double lngone, double lattwo, double lngtwo) {
  16. double radlatone = rad(latone);
  17. double radlattwo = rad(lattwo);
  18. double a = radlatone - radlattwo;
  19. double b = rad(lngone) - rad(lngtwo);
  20. double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2)
  21. + Math.cos(radlatone) * Math.cos(radlattwo)
  22. * Math.pow(Math.sin(b / 2), 2)));
  23. s = s * EARTH_RADIUS;
  24. s = Math.round(s * 10000d) / 10000d;
  25. s = s*1000;
  26. return s;
  27. }
  28. }