博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【JAVA】两点经纬度直线距离的计算
阅读量:4948 次
发布时间:2019-06-11

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

来自谷歌地图的计算公式:

通过JAVA的Math类各种方法调用。实现上述公式

private static double EARTH_RADIUS = 6378.137;// 单位千米	/**	 * 角度弧度计算公式 rad:(). 
* * 360度=2π π=Math.PI * * x度 = x*π/360 弧度 * * @author chiwei * @param d * @return * @since JDK 1.6 */ private static double getRadian(double degree) { return degree * Math.PI / 180.0; } /** * 依据经纬度计算两点之间的距离 GetDistance:().
* * * @author chiwei * @param lat1 * 1点的纬度 * @param lng1 * 1点的经度 * @param lat2 * 2点的纬度 * @param lng2 * 2点的经度 * @return 距离 单位 米 * @since JDK 1.6 */ public static double getDistance(double lat1, double lng1, double lat2, double lng2) { double radLat1 = getRadian(lat1); double radLat2 = getRadian(lat2); double a = radLat1 - radLat2;// 两点纬度差 double b = getRadian(lng1) - getRadian(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; return s * 1000; }
合肥与杭州的经纬度距离计算

public static void main(String ar[]) {		getDistance(31.86, 117.27, 30.26, 120.19);	}
330518米

验证正确。

转载于:https://www.cnblogs.com/claireyuancy/p/7095725.html

你可能感兴趣的文章
python--斐波那契数列
查看>>
mysql查询练习题
查看>>
python学习笔记(session)
查看>>
vue 与原生app的对接交互(混合开发)
查看>>
JavaEE笔记(七)
查看>>
设计模式--原型模式C++实现
查看>>
[LeetCode] 21. Merge Two Sorted Lists_Easy tag: Linked List
查看>>
[Reactive Programming] Using an event stream of double clicks -- buffer()
查看>>
家有Mybatis初养成1
查看>>
mvp学习
查看>>
MySQL缓存分类和配置
查看>>
第二次java作业
查看>>
js 数组
查看>>
P2260 [清华集训2012]模积和
查看>>
Discourse的优化
查看>>
小谈-—ServletConfig对象和servletContext对象
查看>>
python:接口开发
查看>>
Webform和MVC,为什么MVC更好一些?
查看>>
开启浏览器javascrIE6被弃 国产浏览器厂商争食“蛋糕
查看>>
Metropolis(多源点最短路)
查看>>