4

我已经看过几十篇关于此的帖子,所以请不要将其标记为重复,因为它不是。

所以运行以下代码:

private void testLocation(){
    double currentLat = 51.43376;
    double currentLng = -2.86221;

    double destLat = 51.43503; 
    double destLng = -2.86869;

    final float[] results= new float[3];
    Location.distanceBetween(currentLat, currentLng, destLat, destLng, results);
    Log.d("GPS", "results[0]: " + results[0]);
    Log.d("GPS", "results[1]: " + results[1]);
    Log.d("GPS", "results[2]: " + results[2]);


    Location here = new Location("Current");
    here.setLatitude(currentLat);
    here.setLatitude(currentLng);

    Location dest = new Location("Destination2");
    dest.setLatitude(destLat);
    dest.setLongitude(destLng);


    Log.d("GPS", "Bearing to dest: " + here.bearingTo(dest));
    Log.d("GPS", "Distance to dest: " + here.distanceTo(dest));
}

输出是:

04-19 13:39:55.850: D/GPS(12398): results[0]: 472.2533
04-19 13:39:55.860: D/GPS(12398): results[1]: -72.5882
04-19 13:39:55.860: D/GPS(12398): results[2]: -72.59327
04-19 13:39:55.860: D/GPS(12398): Bearing to dest: 120.83207
04-19 13:39:55.860: D/GPS(12398): Distance to dest: 7893878.5

正确的值应该是:距离 472.2533(所以 results[0] 是正确的)。方位角 285.454 度

所以我不知道 results[1] 和 results[2] 给出了什么。而且 BearingTo 和 distanceTo 都给出了完全错误的答案。

这意味着我一定做错了什么。任何人都可以帮忙。通常,我要做的就是计算目标点与当前位置点的距离和方向。如果有人有比上面显示的更好的方法,或者知道我做错了什么,请帮忙。

谢谢亚当

4

2 回答 2

4

计算出的距离存储在 results 中[0]。如果 results 的长度为 2 或更大,则初始方位存储在 results 中[1]。如果结果的长度为 3 或更大,则最终方位存储在结果中[2]-文档

您在这里使用两个不同的值设置纬度两次:

here.setLatitude(currentLat);
here.setLatitude(currentLng);

你在这里混合了纬度/经度值:

dest.setLongitude(destLat);
dest.setLatitude(destLng);

检查并查看是否可以解决您的问题

计算距离和方位的两种方法应该产生相同的结果,因为相同的方法用于计算这些结果。查看SDK 的源代码

于 2013-04-19T13:15:20.763 回答
1

你确定你自己的方位计算是正确的吗?results[2]: -72.59327相当于 287.40673 度。

于 2013-04-19T13:57:58.253 回答