我正在尝试确定MKMapView
. 我正在按照此处(和此处)概述的方法并在 Objective-C 中重写它,但地图的中心是巴芬岛东北部的某个地方,这与两点不相近。
我的方法基于上面链接的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 英里处。