Thanks to a previous question I asked, I am using Color.black.overlay and .clipped() to show an image with letterbox borders above and below it.
But when I attempt to put a button on the top border, it can't be tapped on (I assume because the image (unclipped) is in that space, and is intercepting the tap gesture).
Here is what the layout looks like:
Here is the code:
    var body: some View {
        ZStack {
            Color.black
            VStack {
                topBorder
                imageMiddle
                bottomBorder
            }
        }
        .ignoresSafeArea()
    }
    
    var topBorder: some View {
        return Group {
            ZStack {
                Rectangle()
                    .fill(.green)
                    .frame(minHeight: borderHeight, maxHeight: borderHeight)
                Button {
                    print("tap")
                } label: {
                    Image(systemName: "hand.tap.fill")
                        .foregroundColor(.black)
                }
            }
        }
    }
    
    var bottomBorder: some View {
        return Group {
            Rectangle()
                .fill(.green)
                .frame(minHeight: borderHeight, maxHeight: borderHeight)
        }
    }
    
    var imageMiddle: some View {
        return Group {
            Color.black.overlay(
                Image("cat")
                    .scaledToFill()
            )
            .clipped()
        }
    }
How can I expose that button to a user's tap?


