节选自百度地图API:

若开发者使用的是百度地图或定位API,且版本在1.3.5以后的,

路线规划提供了获取路线距离的方法,见MKRoutePlan 类的 getDistance 方法。

如果是计算任意两点的距离,自2.0.0版本开始,Android SDK为开发者提供了计算距离的接口(DistanceUtil),具体使用方法如下:

  1. GeoPoint p1LL = new GeoPoint(39971802, 116347927);
  2. GeoPoint p2LL = new GeoPoint(39892131, 116498555);
  3. double distance = DistanceUtil.getDistance(p1LL, p2LL);
GeoPoint p1LL = new GeoPoint(39971802, 116347927);

GeoPoint p2LL = new GeoPoint(39892131, 116498555);

double distance = DistanceUtil.getDistance(p1LL, p2LL);

若未使用百度地图或定位SDK,或是地图、定位SDK版本在1.3.5以下的,可以选用以下两种计算方式:

一、利用勾股定理计算,适用于两点距离很近的情况;

二、按标准的球面大圆劣弧长度计算,适用于距离较远的情况;

  1. static double DEF_PI = 3.14159265359; // PI
  2. static double DEF_2PI = 6.28318530712; // 2*PI
  3. static double DEF_PI180 = 0.01745329252; // PI/180.0
  4. static double DEF_R = 6370693.5; // radius of earth
  5. /**
  6. * 第一种方式,按勾股定律求结果
  7. * @param lon1
  8. * @param lat1
  9. * @param lon2
  10. * @param lat2
  11. * @return
  12. * @author kazeik.chen QQ:77132995  2014-4-1下午4:30:09
  13. * TODO kazeik@163.com
  14. */
  15. public double GetShortDistance(double lon1, double lat1, double lon2,
  16. double lat2) {
  17. double ew1, ns1, ew2, ns2;
  18. double dx, dy, dew;
  19. double distance;
  20. // 角度转换为弧度
  21. ew1 = lon1 * DEF_PI180;
  22. ns1 = lat1 * DEF_PI180;
  23. ew2 = lon2 * DEF_PI180;
  24. ns2 = lat2 * DEF_PI180;
  25. // 经度差
  26. dew = ew1 - ew2;
  27. // 若跨东经和西经180 度,进行调整
  28. if (dew > DEF_PI)
  29. dew = DEF_2PI - dew;
  30. else if (dew < -DEF_PI)
  31. dew = DEF_2PI + dew;
  32. dx = DEF_R * Math.cos(ns1) * dew; // 东西方向长度(在纬度圈上的投影长度)
  33. dy = DEF_R * (ns1 - ns2); // 南北方向长度(在经度圈上的投影长度)
  34. // 勾股定理求斜边长
  35. distance = Math.sqrt(dx * dx + dy * dy);
  36. return distance;
  37. }
  38. /**
  39. * 第二种方式,按大圆劣弧求距离
  40. * @param lon1
  41. * @param lat1
  42. * @param lon2
  43. * @param lat2
  44. * @return
  45. * @author kazeik.chen QQ:77132995  2014-4-1下午4:30:30
  46. * TODO kazeik@163.com
  47. */
  48. public double GetLongDistance(double lon1, double lat1, double lon2,
  49. double lat2) {
  50. double ew1, ns1, ew2, ns2;
  51. double distance;
  52. // 角度转换为弧度
  53. ew1 = lon1 * DEF_PI180;
  54. ns1 = lat1 * DEF_PI180;
  55. ew2 = lon2 * DEF_PI180;
  56. ns2 = lat2 * DEF_PI180;
  57. // 求大圆劣弧与球心所夹的角(弧度)
  58. distance = Math.sin(ns1) * Math.sin(ns2) + Math.cos(ns1)
  59. * Math.cos(ns2) * Math.cos(ew1 - ew2);
  60. // 调整到[-1..1]范围内,避免溢出
  61. if (distance > 1.0)
  62. distance = 1.0;
  63. else if (distance < -1.0)
  64. distance = -1.0;
  65. // 求大圆劣弧长度
  66. distance = DEF_R * Math.acos(distance);
  67. return distance;
  68. }
  69. //以下是测试
  70. double mLat1 = 39.90923; // point1纬度
  71. double mLon1 = 116.357428; // point1经度
  72. double mLat2 = 39.90923;// point2纬度
  73. double mLon2 = 116.397428;// point2经度
  74. double distance = GetShortDistance(mLon1, mLat1, mLon2, mLat2);

Android下如何计算两经纬点之间距离的更多相关文章

  1. java如何计算两个日期之间相差多少天?

    java如何计算两个日期之间相差多少天? public static void main(String [] args) { Date now = new Date(); Calendar cal = ...

  2. java如何计算两个经纬度之间的距离?

    /*计算两个经纬度之间的距离 结果单位:米 */public static double getDistance(String lat1Str, String lng1Str, String lat2 ...

  3. php如何计算两个时间戳之间相差的日时分秒

    /功能:计算两个时间戳之间相差的日时分秒//$begin_time 开始时间戳//$end_time 结束时间戳function timediff($begin_time,$end_time){ if ...

  4. windows server/windows同一系统下建立两个目录之间的映射关系

    应用场景,如下: 当两个不同的项目共享同一个资源目录.同一个数据库时,由于两项目根目录不一样,再加上部分项目可能有入口重写规则限制了用户的访问权限. 因此,我们可以利用window 服务器给我们提供的 ...

  5. 在excel中如何计算两个时间之间的差[转]

    因为时间是由序列号所代表的,用户可以用较晚的时间减去较早的时间以得到间隔.例如,单元格A3含有5:30,单元格B3含有14:00,下面的公式返回8:30(间隔8小时30分). =B3-A3 然而,如果 ...

  6. CentOS 下实现两台服务器之间的共享NFS

    NFS的安装配置:centos 5 :yum install nfs-utils portmapcentos 6 :yum install nfs-utils rpcbind yum install ...

  7. fmt标签如何计算两个日期之间相隔的天数

    <h2>start -- ${start}</h2><h2>end -- ${end}</h2><fmt:formatDate var=" ...

  8. Android下如何计算要显示的字符串所占的宽度和高度

    Rect bounds = new Rect(); String text = "Hello World"; TextPaint paint; paint = findViewBy ...

  9. c#(asp.net) 如何计算两个日期之间相隔天数

    1.DateTime t1 = Convert.ToDateTime("2006-1-6"); DateTime t2 = Convert.ToDateTime("200 ...

随机推荐

  1. CH Round #30 摆花[矩阵乘法]

    摆花 CH Round #30 - 清明欢乐赛 背景及描述 艺术馆门前将摆出许多花,一共有n个位置排成一排,每个位置可以摆花也可以不摆花.有些花如果摆在相邻的位置(隔着一个空的位置不算相邻),就不好看 ...

  2. hbase-site.xml中HBASE_CLASSPATH 的设置

    http://www.dataguru.cn/thread-95064-1-1.html

  3. Server Tomcat v6.0 Server at localhost was unable to start within 45 seconds...

    仰天长啸   Server Tomcat v6.0 Server at localhost was unable to start within 45 seconds... 当启动tomcat时候出现 ...

  4. 微信内嵌html5页面清楚缓存

    给每个js添加一个版本号,每次修改js后改变一下版本号,浏览器即可自动刷新不用手动清理缓存 <script src="<%=path%>/js/boss/kpi/redli ...

  5. 物联网(莹石云)WIFI一键配置原理分析(zz)

    最近打算做一款自己的无线传输模块用来实现光伏电站的数据接入,希望可以尽量简化接入流程,其中wifi密码的配置就是一个比较麻烦的事情,想到最近使用萤石摄像头时,wifi密码配置似乎很简单,他们是怎么做到 ...

  6. 转 android 从底部弹出一个popuwindow,渐入渐出效果。我这里是用在购物车需要选择购买选项的操作。

    最近要改客户端,需要实现一个从底部弹出的popuwindow,像我这种渣渣android技术,能整出popuwindow但是整不出动画,百度之,记录一下. 从下面这个地址转的 http://blog. ...

  7. node爬虫之gbk网页中文乱码解决方案

    之前在用 node 做爬虫时碰到的中文乱码问题一直没有解决,今天整理下备忘.(PS:网上一些解决方案都已经不行了) 中文乱码具体是指用 node 请求 gbk 编码的网页,无法正确获取网页中的中文(需 ...

  8. UITableView的使用

    参考:IOS7.0 programming cookbook. http://www.cnblogs.com/kenshincui/p/3931948.html http://blog.csdn.ne ...

  9. WebView·开发指南

    WebView·开车指南 作者:凌俊琦链接:https://zhuanlan.zhihu.com/p/22247021来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. T ...

  10. Web Analytics 2.0 中文翻译 [ 系列索引 ]

    引言 内容概述 第一章:网站分析2.0的新奇世界 第二章:选择你的网络分析灵魂伴侣的最佳策略 第三章:点击流分析的奇妙世界:指标 第四章:点击流分析的奇妙世界:实际的解决方案 第五章:荣耀之钥:度量成 ...