/*
计算两个经纬度之间的距离 结果单位:米
*/
public static double getDistance(String lat1Str, String lng1Str, String lat2Str, String lng2Str) {
Double lat1 = Double.parseDouble(lat1Str);
Double lng1 = Double.parseDouble(lng1Str);
Double lat2 = Double.parseDouble(lat2Str);
Double lng2 = Double.parseDouble(lng2Str); double radLat1 = rad(lat1);
double radLat2 = rad(lat2);
double a = radLat1 - radLat2;
double b = rad(lng1) - rad(lng2);
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)));
s = s * EARTH_RADIUS;
s = Math.round(s * 10000) / 10000;
return s;
}
private static double EARTH_RADIUS = 6378137;

private static double rad(double d) {
return d * Math.PI / 180.0;
}

最新文章

  1. svn强制加注释才能提交
  2. Java 事件机制
  3. pkg-config
  4. 《深入理解Nginx》阅读与实践(三):使用upstream和subrequest访问第三方服务
  5. Linux Shell系列教程之(十七) Shell文件包含
  6. 多校4-Walk Out 分类: 比赛 2015-08-02 17:15 21人阅读 评论(0) 收藏
  7. .NET连接MySql数据库的方法及示例
  8. Javascript 5种方法实现过滤删除前后所有空格
  9. Solr4.8.0源码分析(2)之Solr的启动(一)
  10. 基本 vi 命令
  11. python 小程序—循环和列表训练
  12. angular自定义分页组件(实用)
  13. Jenkins 学习笔记(二):很简单的发布一次
  14. Java-反射初级知识掌握
  15. 人脸姿态校正算法 附完整C++示例代码
  16. commanderJs编写命令行工具(cli)
  17. spring(IOC)动态代理
  18. network / switchboard / jiaohuanji
  19. Java Web之Servlet的三大作用域对象
  20. C#6.0语言规范(三) 基本概念

热门文章

  1. Ubuntu Server 12.04 安装 Jabberd2 服务器
  2. RS:推荐系统中的数据稀疏和冷启动问题
  3. newWindow 弹出的新窗口居中显示
  4. unity3d常用控件
  5. SD卡路径问题以及如何获取SDCard 内存
  6. SpringCloud系列十六:Feign使用Hystrix
  7. memcache命令行
  8. SQL server账号无法登陆
  9. DirectShow中写push模式的source filter流程 + 源码(内附具体凝视)
  10. ecshop3.0.0 release0518 SQL注入