我想显示MKMapView
高度是屏幕高度的一半并忽略顶部边缘。这是我的代码:
import SwiftUI
import MapKit
struct ContentView : View {
var body: some View {
VStack {
MapView()
.border(Color.red, width: 1)
.edgesIgnoringSafeArea(.top)
// .frame(height: UIScreen.main.bounds.height / 2)
Image("turtlerock")
.clipShape(Circle())
.overlay(Circle().stroke(Color.red, lineWidth: 1))
Text("Test")
.font(.title)
}
}
}
我注释掉了框架方法。这些是执行上述代码时的结果(左图),并且没有注释掉 frame 方法(右图):
我们可以检查左边的图像,所以如果没有框架方法,顶部的边缘会被忽略,这很好。在应用帧高度方法的右侧图像中,不再忽略顶部边缘。
据我了解,应用于视图的修饰符的顺序很重要。我尝试了各种命令,但我无法弄清楚如何使用屏幕高度的一半创建 MapView 视图并忽略顶部边缘。MapView 结构定义如下:
import MapKit
import SwiftUI
struct MapView : UIViewRepresentable {
func updateUIView(_ uiView: MKMapView, context: Context) {
let coordinate = CLLocationCoordinate2D(latitude: 34.011286, longitude: -116.166868)
let span = MKCoordinateSpan(latitudeDelta: 2.0, longitudeDelta: 2.0)
let region = MKCoordinateRegion(center: coordinate, span: span)
uiView.setRegion(region, animated: true)
}
func makeUIView(context: Context) -> MKMapView {
MKMapView(frame: .zero)
}
}