• 经纬度之间的距离计算


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

    通过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米

    验证正确。

  • 相关阅读:
    CSS布局之盒子模型[二]
    CSS布局之盒子模型[一]
    CSS文本相关之垂直排列[5]
    网站迁移之后,中文路径都变成乱码
    Linux中shell搜索多文件中的字符串
    mysql数据库报错
    使用Flarum轻松搭建自己的论坛
    CSS雪碧图-html优化
    CSS-定位模式
    ul当做div标签的使用
  • 原文地址:https://www.cnblogs.com/fengli9998/p/8810463.html
Copyright © 2020-2023  润新知