首页 > 代码库 > 【JAVA】两点经纬度直线距离的计算
【JAVA】两点经纬度直线距离的计算
来自谷歌地图的计算公式:
通过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米
验证正确。
【JAVA】两点经纬度直线距离的计算
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。