I'm building a UI is SwiftUI with a list view, and I want to put a panel over part of the list view with a button on it.
On devices with a safe area at the bottom (that don't have a physical home button) I want the panel to go to the bottom of the screen. But I want to make sure that the button on the panel doesn't extend into the safe area.
In my example code, the HStack
is the panel that contains the button. I tried adding .edgesIgnoringSafeArea(.bottom)
to it, but that doesn't allow it to extend to the bottom. This is kind of confusing to me, because the List that's in the same ZStack
extends into the bottom safe area.
When I add .edgesIgnoringSafeArea(.bottom)
to the ZStack
, the HStack
(blue panel) is allowed to extend into the safe area at the bottom of the screen. This is what I want, but then once I do that, how can I tell the Button
that's a child of the HStack
to not ignore the safe area?
I know how I would do this in UIKit, but I'm really hoping to be able to build this UI in SwiftUI. I could manually add some padding or Spacers to add extra padding under the Button
to account for the safe area, but then there would be extra spacing on devices with a home button that don't have a bottom safe area. I'd like to figure out an elegant solution where I can rely on the system to define its safe areas instead of manually defining any spacing numerically or creating conditional situations for different devices.
struct ContentView: View {
var body: some View {
ZStack(alignment: .bottom) {
List {
Text("Item 1")
Text("Item 2")
Text("Item 3")
}
HStack {
Spacer()
Button(action: {
// do something
}){
Text("Button")
.font(.title)
.padding()
.background(Color.green)
.foregroundColor(.white)
.cornerRadius(15)
}.padding()
Spacer()
}.background(Color.blue).edgesIgnoringSafeArea(.bottom)
}
}
}