の 2 つの場所の中間点を特定しようとしていMKMapView
ます。ここ(およびここ) で概説されている方法に従って、Objective-C で書き直しましたが、マップの中心はバフィン島の北東のどこかにあり、2 つのポイントの近くにはありません。
上記のリンクにある Java メソッドに基づく私のメソッド:
+(CLLocationCoordinate2D)findCenterPoint:(CLLocationCoordinate2D)_lo1 :(CLLocationCoordinate2D)_loc2 {
CLLocationCoordinate2D center;
double lon1 = _lo1.longitude * M_PI / 180;
double lon2 = _loc2.longitude * M_PI / 100;
double lat1 = _lo1.latitude * M_PI / 180;
double lat2 = _loc2.latitude * M_PI / 100;
double dLon = lon2 - lon1;
double x = cos(lat2) * cos(dLon);
double y = cos(lat2) * sin(dLon);
double lat3 = atan2( sin(lat1) + sin(lat2), sqrt((cos(lat1) + x) * (cos(lat1) + x) + y * y) );
double lon3 = lon1 + atan2(y, cos(lat1) + x);
center.latitude = lat3 * 180 / M_PI;
center.longitude = lon3 * 180 / M_PI;
return center;
}
2 つのパラメーターには、次のデータがあります。
_loc1:
latitude = 45.4959839
longitude = -73.67826455
_loc2:
latitude = 45.482889
longitude = -73.57522299
上記はマップ上に正しく配置されています (モントリオール内および周辺)。私は2つの中間点にマップを配置しようとしていますが、私のメソッドは次を返します:
latitude = 65.29055
longitude = -82.55425
北極圏のどこかで、南に約 500 マイルあるはずです。