博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java 根据两个经纬度,得到两点距离
阅读量:5349 次
发布时间:2019-06-15

本文共 873 字,大约阅读时间需要 2 分钟。

private static final double EARTH_RADIUS = 6371000;//赤道半径(单位m)
private static final double INTEGR_NUM = 10000;
/**
* 基于googleMap中的算法得到两经纬度之间的距离,误差 <= 0.2m
* @param lat1 第一点的精度
* @param lng1 第一点的纬度
* @param lat2 第二点的精度
* @param lng2 第二点的纬度
* @return 返回的距离,单位m
* */
public static double distance(double lat1, double lng1, double lat2, double lng2) {
double x1 = Math.cos(lat1) * Math.cos(lng1);
double y1 = Math.cos(lat1) * Math.sin(lng1);
double z1 = Math.sin(lat1);
double x2 = Math.cos(lat2) * Math.cos(lng2);
double y2 = Math.cos(lat2) * Math.sin(lng2);
double z2 = Math.sin(lat2);
double lineDistance =
Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2) + (z1 - z2) * (z1 - z2));
double s = EARTH_RADIUS * Math.PI * 2 * Math.asin(0.5 * lineDistance) / 180;
return Math.round(s * INTEGR_NUM) / INTEGR_NUM;
}

转载于:https://www.cnblogs.com/Soy-technology/p/10980807.html

你可能感兴趣的文章
Linux常用命令(九)
查看>>
Linux常用命令(十一)
查看>>
Linux常用命令(十)
查看>>
实验吧之这就是一个坑
查看>>
Linux常用命令(十二)
查看>>
Linux常用命令(十三)
查看>>
Linux常用命令(十五)
查看>>
Linux常用命令(十四)
查看>>
Linux常用命令(十七)
查看>>
Linux常用命令(十六)
查看>>
Linux常用命令(二十四)
查看>>
4种java定时器
查看>>
Vue.js 教程
查看>>
linux 设置网卡
查看>>
hive 语法 case when 语法
查看>>
Ajax:js读取txt内容(json格式内容)
查看>>
Task 7 买书最低价格问题
查看>>
Selenium3+python自动化007-警告框
查看>>
html5 相同形状的图形进行循环
查看>>
springboot中文官方文档
查看>>