使用距离计算纬度和经度的点

时间:2014-09-25 11:08:16

标签: java gps latitude-longitude

我正在尝试从纬度和经度位置以及距离和方位计算一个点,但我混淆了我的数学,可能搞乱了单位。有人可以提供帮助吗?这是我的代码:

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。任何指针都表示赞赏!

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

1 个答案:

答案 0 :(得分:1)

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

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

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