缩放 MapView 以显示 180 度经线上的注释

Zoom MapView to show annotations across 180th meridian

我有一个带有 <5 个注释的 MapView。加载地图时,我想放大以使地图在这些注释上居中,例如 this。但是,当注释分布在第 180 条子午线上(经度从 -180 到 +180)时,链接方法不起作用。即使它们聚集在本初子午线周围,我如何才能稳健地缩放到注释?

例如,如果我有 x(0,179) 和 y(0,-179),那么我想要一个宽度为经度两度而不是 358 度的包含矩形。

iOS 的 MapKit 实际上在 MKMapView 中有一个内置函数可以执行此操作:

showAnnotations(annotations: [MKAnnotation], animated: Bool)

但是,这个函数不提供对缩放级别的控制,所以我还是得自己做一个函数。这是伪代码:

zoomToAnnotations(annotations, zoomLimit) {
    // calculate the midpoint as the average latitude and longitude
    average_latitude = mean(a.coordinate.latitude for a in annotations)
    average_longitude = atan2(mean(sin(a.coordinate.longitude) for a in annotations), mean(cos(a.coordinate.longitude) for a in annotations)) // be careful with degrees and radians in real code
    regular_midpoint = coordinate(average_latitude, average_longitude)
    // subtract 180 from longitude for the midpoint of the region crossing the meridian
    meridian_midpoint = coordinate(average_latitude, average_longitude - 180.0)
    if (meridian_midpoint.longitude < -180) {
        meridian_midpoint.longitude += 360.0
    }

    // work out which region will be smaller and center map there
    meridian_sum = sum(a.coordinate.distance(meridian_midpoint) for a in annotations)
    regular_sum = sum(a.coordinate.distance(regular_midpoint) for a in annotations)
    regular_max_distance = max(a.coordinate.distance(regular_midpoint) for a in annotations)
    if meridian_sum < regular_sum {
        meridian_max_distance = max(a.coordinate.distance(meridian_midpoint) for a in annotations)
        centerMapWithRadius(meridian_midpoint, max(zoomLimit, meridian_max_distance))
    } else {
       regular_max_distance = max(a.coordinate.distance(regular_midpoint) for a in annotations)
        centerMapWithRadius(regular_midpoint, max(zoomLimit, regular_max_distance))
    }
}

这种方法并不完美,因为它以点的平均值为中心,而不是让最远的点与边缘的距离相等。