码迷,mamicode.com
首页 > 其他好文 > 详细

经纬度之间的距离计算

时间:2018-04-12 22:31:25      阅读:164      评论:0      收藏:0      [点我收藏+]

标签:math类   []   sdn   分享图片   方法调用   ble   str   water   谷歌地图   

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

技术分享图片

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

 

private static double EARTH_RADIUS = 6378.137;// 单位千米

	/**
	 * 角度弧度计算公式 rad:(). <br/>
	 * 
	 * 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:(). <br/>
	 * 
	 * 
	 * @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米

 

验证正确。

经纬度之间的距离计算

标签:math类   []   sdn   分享图片   方法调用   ble   str   water   谷歌地图   

原文地址:https://www.cnblogs.com/fengli9998/p/8810463.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!