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
,以使用户可以拍摄新照片而不是导入现有照片。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法