java实现千米与经纬度度数的转换(画圆左右有精度缺失)

java实现千米与经纬度度数的转换(画圆左右有精度缺失)

大家好,我是架构君,一个会写代码吟诗的架构师。今天说一说java实现千米与经纬度度数的转换(画圆左右有精度缺失),希望能够帮助大家进步!!!

public class Tools {

	public static final double earthRadius  = 6371.393;//地球半径:km
	
	/**
     * 将公里数转换为度数
     * @param l
     * @return
     */
    public static Double km2Degree(Double l){
        //公式:l(弧长)=degree(圆心角)× π(圆周率)× r(半径)/180
        //转换后的公式:degree(圆心角)=l(弧长) × 180/(π(圆周率)× r(半径))
        Double degree = (180/earthRadius/Math.PI)*l;
        return degree;
    }
    /**
     * 将度数转换为公里数
     * @param degree
     * @return
     */
    public static Double degree2Km(Double degree){
        //公式:l(弧长)=degree(圆心角)× π(圆周率)× r(半径)/180
        Double l = earthRadius/180*Math.PI*degree;//将180放在前面,降低数值
        return l;
    }
    public static void main(String[] args){//测试
        System.out.println("1公里="+km2Degree(1.0)+"度");//单位是公里
        System.out.println("1度="+degree2Km(1.0)+"公里");//单位是度
    }
}

 

本文来源huayang183,由架构君转载发布,观点不代表Java架构师必看的立场,转载请标明来源出处:https://javajgs.com/archives/18218

发表评论