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