ios - 如何使用 SwiftUI 在导航栏上添加按钮

标签 ios swift uiview swiftui navigationbar

我有两个结构 ContentView.swift

struct ContentView: View {
    var body: some View {
        NavigationView{
            ZStack {
                Color(red: 0.09, green: 0.63, blue: 0.52)
                    .edgesIgnoringSafeArea(.all)

                VStack {
                    Image("flower_logo")
                        .resizable()
                        .aspectRatio(contentMode: .fit)
                        .frame(width: 150.0, height: 150.0)
                        .clipShape(Circle())

                    Text("ScanFlower")
                        .font(Font.custom("Pacifico-Regular", size: 40))
                        .bold()
                        .foregroundColor(.white)

                    Text("DETECT FLOWER SPECIES")
                        .foregroundColor(.white)
                        .font(.system(size: 15))

                    Spacer()
                        .frame(height: 100)

                    NavigationLink(destination: ScanWithCamera()){
                        NavigateButtons(imageName: "camera.fill", text: "Scan with camera")
                    }

                    NavigateButtons(imageName: "photo.fill", text: "Use pictures")
                    NavigateButtons(imageName: "chart.bar.fill", text: "Check your database")
                }
            }
        }

    }
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

移至第二个 View ScanWithCamera.swift通过单击 NavigationLink“使用相机扫描”。在 ScanWithCamera.swift
struct ScanWithCamera: View {
    var body: some View {
        NavigationView{
            Text("Damn...bro...")
                .navigationBarTitle("Page2",displayMode: .inline)
            .navigationBarItems(leading:
                Button(action: {
                    print("Edit button pressed...")
                }) {
                    Text("Edit")
                }
            )
        }

    }
}

struct ScanWithCamera_Previews: PreviewProvider {
    static var previews: some View {
        ScanWithCamera()
    }
}

struct ScanWithCamera_Previews: PreviewProvider {
    static var previews: some View {
        ScanWithCamera()
    }
}

我想在导航栏上有一个按钮,但我不知道如何在那里添加它。当我尝试使用 .navigationBarItems ,我有几乎一半屏幕的导航栏enter image description here就像在屏幕上一样。如何在此处添加此按钮以使导航栏不增加?

最佳答案

您可以使用以下代码

如果你想在后面显示编辑......你可以这样做

struct DestinationView: View {
    var body: some View {
        List {
            Text("1")
        }
        .navigationBarTitle("Destination")
        .navigationBarItems(leading:

             Button("Edit") {
               print("About tapped!")
               }
        ).navigationBarBackButtonHidden(true)
    }
}

结果
enter image description here

如果您想用多个按钮示例显示回来
struct DestinationView: View {
    var body: some View {
        List {
            Text("1")
            Text("2")
        }
        .navigationBarTitle("DestinationView")
        .navigationBarItems(leading: HStack {
                Button("Back") {
                    print("About tapped!")
                }.background(Color.black)
                    .foregroundColor(Color.white)

                Button("Help") {
                    print("Help tapped!")
                }
                }, trailing:
                HStack {

                    Button("About") {
                        print("About tapped!")
                    }

                    Button("Info") {
                        print("Help tapped!")
                    }
                }
        )

    }
}

结果

enter image description here

如果你想要 .inline 和多个按钮
struct DestinationView: View {
    var body: some View {
        List {
            Text("1")
            Text("2")
        }
        .navigationBarTitle("Destination")
        .navigationBarItems(leading: HStack {
                Button("Back") {
                    print("About tapped!")
                }.background(Color.black)
                    .foregroundColor(Color.white)

                Button("Help") {
                    print("Help tapped!")
                }
                }, trailing:
                VStack {

                    Button("About") {
                        print("About tapped!")
                    }

                    Button("Info") {
                        print("Help tapped!")
                    }.foregroundColor(Color.red)
                }
        )


    }
}

结果
enter image description here

关于ios - 如何使用 SwiftUI 在导航栏上添加按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61784128/

相关文章:

ios - 为什么 CGBitmapContextCreateImage 比 [UIImage initWithData :]? 慢

ios - 我应该在接口(interface)中声明变量还是在 objective-c arc 中使用属性?

ios - 获取所有可供选择的文件和文件夹

ios - 添加到管理对象有序集

ios - 向 UIScrollView 中的标准 Pan Gesture Recognizer 添加功能

ios - iOS 中的信用卡支付(3-D 安全?)

ios - Autolayout:原点和大小应根据宽度和高度因素改变

ios - Main.storyboard : Internal error. 请在 Xcode 7.2 中提交错误

ios - UIView autoresizingMask 在设置不同的固定左右边距和灵活宽度时出现错误?

ios - UIScrollView 中 subview 放错位置