【问题标题】:How to compute MKMapCamera centerCoordinateDistance programmatically in SwiftUI如何在 SwiftUI 中以编程方式计算 MKMapCamera centerCoordinateDistance
【发布时间】:2020-06-15 06:00:41
【问题描述】:

我有一个 SwiftUI MapKitView,它遵循 https://www.hackingwithswift.com/books/ios-swiftui/advanced-mkmapview-with-swiftui 中适用于 macOS 的模式。在makeNSView 中,我为我想要显示的位置的有趣位设置了区域,与窗口大小无关,并且默认情况下,无论 NSWindow 是横向多于纵向还是反之亦然,我都可以让此代码适当缩放。

 func makeNSView(context: Context) -> MKMapView {
    let mapView = MKMapView()
    mapView.delegate = context.coordinator
    mapView.mapType = .satellite
    mapView.pointOfInterestFilter = .excludingAll
    let region = MKCoordinateRegion(center: centroid, latitudinalMeters: 1160, longitudinalMeters: 1260)
    let fittedRegion = mapView.regionThatFits(region)
    mapView.setRegion(fittedRegion, animated: false)
}

看起来mapView.regionsetRegion()返回时实际上并没有更新

问题是我想定位地图而不是正北,所以我必须设置一个相机。

但是,创建 MKMapCamera 时的fromDistance: 参数必须根据设置的区域计算,但是相机的视场角是多少才能确定一次包含窗口的正确范围需要多高地区定了?我基本上希望缩放级别设置与通过fittedRegion 设置的相同,并希望在更改了航向的相机中复制它(间距为 0)

看来MKMapViewDelegate 有一个mapViewDidChangeVisibleRegion,我认为协调器是SwiftUI 中的代表。我可以在多次调用updateNSView 时看到该区域,但在实际设置之前需要进行几次调用。我怀疑将相机设置在那里会创建另一个updateNSView() 调用,这会带来问题。

如何定位地图以包含给定区域范围,而不管窗口大小与初始加载时的缩放级别和航向(但随后让用户按照他们认为合适的方式进行操作)..

【问题讨论】:

    标签: macos swiftui mapkit


    【解决方案1】:

    试试下面的

    func makeNSView(context: Context) -> MKMapView {
        let mapView = MKMapView()
        mapView.delegate = context.coordinator
        mapView.mapType = .satellite
        mapView.pointOfInterestFilter = .excludingAll
        let region = MKCoordinateRegion(center: centroid, latitudinalMeters: 1160, longitudinalMeters: 1260)
        let fittedRegion = mapView.regionThatFits(region)
    
        DispatchQueue.main.async {
           mapView.setRegion(fittedRegion, animated: false)
        }
        return mapView
    }
    

    【讨论】:

      【解决方案2】:

      我想我明白了。

      在 Coordinator 中响应 func mapViewDidFinishLoadingMap(_ mapView: MKMapView) 并将 mapView.camera.heading 设置为适当的值,这就是我想要的。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 2020-07-06
        • 2021-05-31
        • 2023-01-11
        • 1970-01-01
        • 2010-09-16
        • 2014-12-15
        相关资源
        最近更新 更多