1

MKCoordinateRegion を作成して、定義された 2 つのポイントを含むマップを表示する次のコードがあります。問題は、経度が 180 度または -180 度を超えると機能しないことです。

CLLocationCoordinate2D tempPoint1 = CLLocationCoordinate2DMake(startLat,startLong);
CLLocationCoordinate2D tempPoint2 = CLLocationCoordinate2DMake(nextLat,nextLong);

if (lineType == 1) {
    [self createGreatCircleMKPolylineFromPoint: tempPoint1 toPoint: tempPoint2 forMapView:mapView];
}
else  {
    CLLocationCoordinate2D *coords = malloc(sizeof(CLLocationCoordinate2D) * 2);
    coords[0] = tempPoint1;
    coords[1] = tempPoint2;

    MKPolyline *polyline = [MKPolyline polylineWithCoordinates:coords count:2];
    free(coords);
    [mapView addOverlay:polyline];

}

double lon1 = tempPoint1.longitude * M_PI / 180;
double lon2 = tempPoint2.longitude * M_PI / 180;

double lat1 = tempPoint1.latitude * M_PI / 180;
double lat2 = tempPoint2.latitude * M_PI / 180;

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);

CLLocationCoordinate2D center;

center.latitude  = lat3 * 180 / M_PI;
center.longitude = lon3 * 180 / M_PI;


MKCoordinateSpan locationSpan;
locationSpan.latitudeDelta = fabs(tempPoint1.latitude - tempPoint2.latitude) * 1.2;
locationSpan.longitudeDelta = fabs(tempPoint1.longitude - tempPoint2.longitude) * 1.2;
MKCoordinateRegion region = {center, locationSpan};

[mapView setRegion:region];

このコードを変更して、startLong が正の値、つまり 174 で、nextLong が負の値、つまり -127、またはその逆を処理できるようにする方法を教えてください。

4

1 に答える 1

0

とは度単位の経度startLongであるため、0° から 360° の範囲で、両方が正で>=nextLongであることを確認できます。nextLongstartLong

while( startLong < 0.0 ) startLong += 360.0f;
while( startLong >= 360.0 ) startLong -= 360.0f;
while( nextLong < startLong ) nextLong += 360.0f;
while( nextLong - startLong > 360.0 ) nextLong -= 360.0;

これにより、次のことを確認できます。

  • startLong0.0 から 360.0 の間 (後者は排他的)
  • nextLongstartLongstartLong+ 360.0の間
于 2015-05-06T13:30:55.627 に答える