SafeAreaInset
- 디바이스 화면 SafeArea에 콘텐츠 뷰 추가
safeAreaInset
- 디바이스 화면의 가장자리 등 SafeArea에 여백을 추가하여 뷰를 배치할 수 있다.
struct SafeAreaInsetStudy: View {
var body: some View {
NavigationStack {
List(0..<10) { _ in
Rectangle()
.frame(height: 200)
}
.navigationTitle("Safe Area")
.safeAreaInset(edge: .bottom, alignment: .center, spacing: nil) {
Button("test") {
}
.frame(maxWidth: .infinity)
.background(Color.green)
}
}
}
}
data:image/s3,"s3://crabby-images/9b2ea/9b2ea26028514a05285e84c9dc11560da8d3753c" alt=""
navigationTitle
이 존재하는 상황에서 상단에 뷰를 추가할 경우, navigationTitle
영역을 포함한다.
struct SafeAreaInsetStudy: View {
var body: some View {
NavigationStack {
List(0..<10) { _ in
Rectangle()
.frame(height: 200)
}
.navigationTitle("Safe Area")
.safeAreaInset(edge: .top, alignment: .center, spacing: nil) {
Button("test") {
}
.frame(maxWidth: .infinity)
.background(Color.green)
}
}
}
}
data:image/s3,"s3://crabby-images/e56db/e56dbd3f4c55cc91f26286ac6a8ef4c735f753ed" alt=""
- 그러나 추가하는 뷰 하단의 SafeArea를 무시하는 경우,
navigationTitle
영역을 포함하지 않는다.
struct SafeAreaInsetStudy: View {
var body: some View {
NavigationStack {
List(0..<10) { _ in
Rectangle()
.frame(height: 200)
}
.navigationTitle("Safe Area")
.safeAreaInset(edge: .top, alignment: .center, spacing: nil) {
Button("test") {
}
.frame(maxWidth: .infinity)
.background(Color.green.edgesIgnoringSafeArea(.bottom))
}
}
}
}
data:image/s3,"s3://crabby-images/e5680/e56800a04cbdc39bedafa26f0e26629cb9671e1a" alt=""