Determinação do ponto médio entre 2 cooridinatos
Eu estou tentando determinar o ponto médio entre os locais em umMKMapView
. Eu estou seguindo o método descritoAqui (eAqui) e reescreveu-o em Objective-C, mas o mapa está a ser centrado algures a nordeste da ilha de Baffin, que não é onde se situam os dois pontos.
Meu método baseado no método java vinculado acima:
<code>+(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; } </code>
Os dois parâmetros possuem os seguintes dados:
<code>_loc1: latitude = 45.4959839 longitude = -73.67826455 _loc2: latitude = 45.482889 longitude = -73.57522299 </code>
Os itens acima são colocados corretamente no mapa (em Montreal e arredores). Estou tentando centralizar o mapa no ponto médio entre os 2, mas meu método retorna o seguinte:
<code>latitude = 65.29055 longitude = -82.55425 </code>
que algures no ártico, quando deveria estar a cerca de 500 milhas a sul.