2014-09-25 56 views
0

我想从经度和纬度位置以及距离和方位计算出一个点,但是我混淆了我的数学,可能弄乱了单位。有没有人可以帮忙?这是我的代码:从经纬度计算出一个点的距离

public static double[] distFromPointWithDistance(float lat1Deg, float lng1Deg, float d, float brngDeg) { 
    double lat1 = Math.toRadians(lat1Deg); 
    double lng1 = Math.toRadians(lng1Deg); 
    double brng = Math.toRadians(brngDeg); 

    double R = 6371; //kilometers 
    double lat2 = Math.asin(Math.sin(lat1)*Math.cos(d/R) + 
      Math.cos(lat1)*Math.sin(d/R)*Math.cos(brng)); 
    double lng2 = lng1 + Math.atan2(Math.sin(brng)*Math.sin(d/R)*Math.cos(lat1), 
      Math.cos(d/R)-Math.sin(lat1)*Math.sin(lat2)); 

    double[] result = new double[2]; 
    result[0] = lat2; 
    result[1] = lng2; 
    return result; 
} 

对于lat1Deg:41.884344 对于lng1Deg:12.479627 对于DIST:1 对于brngDeg:90

我所期待的是41°53'04“N,012 °29'30“E,但我得到了完全不同的东西,lat2 = 0.73101。任何指针都表示赞赏!

[编辑]: 我添加了转换,但仍然得到非常奇怪的结果

+2

在使用trig函数之前,将所有角度从度数转换为弧度。 – duffymo 2014-09-25 11:11:29

回答

0

乍一看您的公式看起来是正确的。

Java的三角函数在弧度,而不是你所假设的程度。

将度数转换为弧度,乘以Pi/180

+0

我加了这个:double lat1 = lat1Deg * Math.PI/180; double lng1 = lng1Deg * Math.PI/180; double brng = brngDeg * Math.PI/180;这应该做到这一点不应该吗? – 2014-09-25 15:35:12

相关问题