100 Days of SwiftUI —— Day 78:Time for MapKit

时间:2022-07-24
本文章向大家介绍100 Days of SwiftUI —— Day 78:Time for MapKit,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

昨天您构建了一个新应用,该应用可以从用户库中导入照片,并希望您对最终产品感到满意——或至少在最终产品方面取得了很大进展。

但是您的老板进来并要求一个新功能:当您查看导入的图片时,您应该显示一个地图,上面有一个图钉,标出添加该图钉时的位置。它可能与照片并排在同一屏幕上,也可能使用分段控件显示或隐藏,或者它在不同的屏幕上——取决于您。无论如何,您都知道如何放置图钉,也知道如何使用地图视图的中心坐标,因此,唯一需要弄清楚的是如何获取用户的位置,以与他们的文本和图像一起保存。

尽管我确实希望您提高自己的技能,但我并不残酷。因此,这是一个获取用户位置的类:

import CoreLocation

class LocationFetcher: NSObject, CLLocationManagerDelegate {
    let manager = CLLocationManager()
    var lastKnownLocation: CLLocationCoordinate2D?

    override init() {
        super.init()
        manager.delegate = self
    }

    func start() {
        manager.requestWhenInUseAuthorization()
        manager.startUpdatingLocation()
    }

    func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
        lastKnownLocation = locations.first?.coordinate
    }
}

要使用该功能,请在 Info.plist 中添加一个名为“Privacy - Location When In Use Usage Description”的新密钥,然后为其提供某种值,向用户解释为什么需要他们的位置。

现在您可以在SwiftUI视图中使用它,如下所示:

struct ContentView: View {
    let locationFetcher = LocationFetcher()

    var body: some View {
        VStack {
            Button("Start Tracking Location") {
                self.locationFetcher.start()
            }

            Button("Read Location") {
                if let location = self.locationFetcher.lastKnownLocation {
                    print("Your location is (location)")
                } else {
                    print("Your location is unknown")
                }
            }
        }
    }
}

如果您使用的是模拟器而不是真实的设备,则可以通过转到“Feature”菜单并选择 Location > Apple 来伪造位置。

现在就交给您了:您可以添加老板想要的功能,并将MapKit,UIKit和SwiftUI集成到单个应用程序中。

提示:如果要使您的应用真正有用,请尝试将图像选择器控制器的sourceType属性设置为.camera,以使用户可以拍摄新照片而不是导入现有照片。