我已经看过几十篇关于此的帖子,所以请不要将其标记为重复,因为它不是。
所以运行以下代码:
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 都给出了完全错误的答案。
这意味着我一定做错了什么。任何人都可以帮忙。通常,我要做的就是计算目标点与当前位置点的距离和方向。如果有人有比上面显示的更好的方法,或者知道我做错了什么,请帮忙。
谢谢亚当