Java实现根据经纬度计算距离

在项目开发过程中,需要根据两地经纬度坐标计算两地间距离,所用的工具类如下:

Demo1:

  1. public static double getDistatce(double lat1, double lat2, double lon1, double lon2) {
  2. double R = 6371;
  3. double distance = 0.0;
  4. double dLat = (lat2 - lat1) * Math.PI / 180;
  5. double dLon = (lon2 - lon1) * Math.PI / 180;
  6. double a = Math.sin(dLat / 2) * Math.sin(dLat / 2)
  7. + Math.cos(lat1 * Math.PI / 180)
  8. * Math.cos(lat2 * Math.PI / 180) * Math.sin(dLon / 2)
  9. * Math.sin(dLon / 2);
  10. distance = (2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a))) * R;
  11. return distance;
  12. }

Demo2:

  1. private static final double EARTH_RADIUS = 6378.137 * 1000;
  2. private static double rad(double d)
  3. {
  4. return d * Math.PI / 180.0;
  5. }
  6. public static double GetDistance(double lat1, double lng1, double lat2, double lng2)
  7. {
  8. double radLat1 = rad(lat1);
  9. double radLat2 = rad(lat2);
  10. double a = radLat1 - radLat2;
  11. double b = rad(lng1) - rad(lng2);
  12. double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) +
  13. Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));
  14. s = s * EARTH_RADIUS ;
  15. s = Math.round(s * 10000) / 10000;
  16. return s;
  17. }

Demo3:

  1. private static final double EARTH_RADIUS = 6378137;//赤道半径(单位m)
  2.  
  3. /**
  4. * 转化为弧度(rad)
  5. * */
  6. private static double rad(double d)
  7. {
  8. return d * Math.PI / 180.0;
  9. }
  10.  
  11. /**
  12. * 基于余弦定理求两经纬度距离
  13. * @param lon1 第一点的精度
  14. * @param lat1 第一点的纬度
  15. * @param lon2 第二点的精度
  16. * @param lat3 第二点的纬度
  17. * @return 返回的距离,单位km
  18. * */
  19. public static double LantitudeLongitudeDist(double lon1, double lat1,double lon2, double lat2) {
  20. double radLat1 = rad(lat1);
  21. double radLat2 = rad(lat2);
  22.  
  23. double radLon1 = rad(lon1);
  24. double radLon2 = rad(lon2);
  25.  
  26. if (radLat1 < 0)
  27. radLat1 = Math.PI / 2 + Math.abs(radLat1);// south
  28. if (radLat1 > 0)
  29. radLat1 = Math.PI / 2 - Math.abs(radLat1);// north
  30. if (radLon1 < 0)
  31. radLon1 = Math.PI * 2 - Math.abs(radLon1);// west
  32. if (radLat2 < 0)
  33. radLat2 = Math.PI / 2 + Math.abs(radLat2);// south
  34. if (radLat2 > 0)
  35. radLat2 = Math.PI / 2 - Math.abs(radLat2);// north
  36. if (radLon2 < 0)
  37. radLon2 = Math.PI * 2 - Math.abs(radLon2);// west
  38. double x1 = EARTH_RADIUS * Math.cos(radLon1) * Math.sin(radLat1);
  39. double y1 = EARTH_RADIUS * Math.sin(radLon1) * Math.sin(radLat1);
  40. double z1 = EARTH_RADIUS * Math.cos(radLat1);
  41.  
  42. double x2 = EARTH_RADIUS * Math.cos(radLon2) * Math.sin(radLat2);
  43. double y2 = EARTH_RADIUS * Math.sin(radLon2) * Math.sin(radLat2);
  44. double z2 = EARTH_RADIUS * Math.cos(radLat2);
  45.  
  46. double d = Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2)+ (z1 - z2) * (z1 - z2));
  47. //余弦定理求夹角
  48. double theta = Math.acos((EARTH_RADIUS * EARTH_RADIUS + EARTH_RADIUS * EARTH_RADIUS - d * d) / (2 * EARTH_RADIUS * EARTH_RADIUS));
  49. double dist = theta * EARTH_RADIUS;
  50. return dist;
  51. }

Demo4:

  1. //google map
  2. private static final double EARTH_RADIUS = 6378137;//赤道半径(单位m)
  3.  
  4. /**
  5. * 转化为弧度(rad)
  6. * */
  7. private static double rad(double d)
  8. {
  9. return d * Math.PI / 180.0;
  10. }
  11. /**
  12. * 基于googleMap中的算法得到两经纬度之间的距离,计算精度与谷歌地图的距离精度差不多,相差范围在0.2米以下
  13. * @param lon1 第一点的精度
  14. * @param lat1 第一点的纬度
  15. * @param lon2 第二点的精度
  16. * @param lat3 第二点的纬度
  17. * @return 返回的距离,单位km
  18. * */
  19. public static double GetDistance(double lon1,double lat1,double lon2, double lat2)
  20. {
  21. double radLat1 = rad(lat1);
  22. double radLat2 = rad(lat2);
  23. double a = radLat1 - radLat2;
  24. double b = rad(lon1) - rad(lon2);
  25. double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2)+Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));
  26. s = s * EARTH_RADIUS;
  27. s = Math.round(s * 10000) / 10000;
  28. return s;
  29. }

java工具类(六)根据经纬度计算距离的更多相关文章

  1. Java工具类之浮点精确计算

    public class Arith { // 默认除法运算精度 private static final int DEF_DIV_SCALE = 10; // 构造器私有,让这个类不能实例化 pri ...

  2. 第一章 Java工具类目录

    在这一系列博客中,主要是记录在实际开发中会常用的一些Java工具类,方便后续开发中使用. 以下的目录会随着后边具体工具类的添加而改变. 浮点数精确计算 第二章 Java浮点数精确计算 crc32将任意 ...

  3. 排名前 16 的 Java 工具类

    在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取的5万个开源项目源码. 一. ...

  4. 排名前16的Java工具类

    原文:https://www.jianshu.com/p/9e937d178203 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法 ...

  5. 干货:排名前16的Java工具类

    在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取的5万个开源项目源码. 一. ...

  6. 常用高效 Java 工具类总结

    一.前言 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取的5万个开源项目源码 ...

  7. 几种高效的Java工具类推荐

    本文将介绍了十二种常用的.高效的Java工具类 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类. 在开发中,使用这些工具类,不仅可以提高编码效率,还 ...

  8. 16 个超级实用的 Java 工具类

    阅读本文大概需要 4 分钟. 出处:alterem juejin.im/post/5d4a25b351882505c105cc6e 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用 ...

  9. 超级实用的 Java 工具类

    超级实用的 Java 工具类 在Java中,工具类定义了一组公共方法,这篇文章将介绍Java中使用最频繁及最通用的Java工具类.以下工具类.方法按使用流行度排名,参考数据来源于Github上随机选取 ...

随机推荐

  1. 采购订单状态更改处理API

    --PO采购订单状态更改处理API PO_Document_Control_PUB.control_document( p_api_version IN NUMBER, p_init_msg_list ...

  2. Swift中不用桥接文件和.h头文件直接和C代码交互的方法

    我们知道一般情况下Swit要想调用obj-c,c或c++代码必须通过obj-c以及桥接文件才可以办到,但是对于某些简单的代码,我们可以跳过桥接文件和.h头文件,直接和C代码交互呢! 我们再Projec ...

  3. linux添加环境变量(path)

    分为三步 1.sudo vim /etc/profile 2.export PATH="全路径:$PATH" 3.source /etc/profile 我的微信二维码如下,欢迎交 ...

  4. Gazebo機器人仿真學習探索筆記(四)模型編輯

    模型編輯主要是自定義編輯物體模型構建環境,也可以將多種模型組合爲新模型等,支持外部模型導入, 需要注意的導入模型格式有相應要求,否在無法導入成功, COLLADA (dae), STereoLitho ...

  5. [ExtJS5学习笔记]第二十七节 CMD打包错误 Error C2009: YUI Parse Error (identifier is a reserved word => debugger;)

    本文地址:http://blog.csdn.net/sushengmiyan/article/details/41242993 本文作者:sushengmiyan ------------------ ...

  6. 15 ActionBar 总结

    ActionBar 一, 说明 是一个动作栏 是窗口特性 提供给用户动作 导航模式 可以适配不同的屏幕 二, ActionBar 提供的功能 1. 显示菜单项 always:总是展示到ActionBa ...

  7. 5.2、Android Studio截图

    Android Monitor允许你截取连接的设备或者虚拟机的屏幕,保存为PNG格式. 设备截图 1. 打开一个项目 2. 在设备或虚拟机中运行应用 3. 显示Android Monitor 4. 切 ...

  8. 【ShaderToy】开篇

    写在前面 呜呼,好久没有写博客了,好惭愧.题外话,感觉越大就越想家,希望可以一直和家人在一起,哪怕只是坐在一起不说话也觉得很温暖,一想到要分开眼睛就开始酸,哎.开学还是爬上来老实更新博客学习吧~ 今天 ...

  9. 1.QT中的容器QVector,QList,QSet,QMap,QQueue,QStack,QMultiMap,QSingleList等

    1  新建一个项目 在pro文件中只需要加上CONFIG += C++11 main.cpp #include <QMap> int main() { QMap<int,QStrin ...

  10. Transform介绍(Unity3D开发之二)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2D开发网–Cocos2Dev.com,谢谢! 原文地址: http://www.cocos2dev.com/?p=491 可能unity中接触较早的 ...