• 如何在 SwiftUI 中创建悬浮操作按钮


    在这里插入图片描述

    前言

    悬浮操作按钮(Floating Action Button, FAB)是一种在 Android 和 Material Design 中使用的 UI 元素。它用于触发特定屏幕的主要操作。

    尽管它来自 Android,但在一些 iOS 应用中也可以看到这种模式。

    以下是 Twitter 应用中悬浮操作按钮的示例。Twitter App 在最重要的操作步骤,发布推文时使用悬浮操作按钮。如下图,在右下角有一个蓝底中间有加号的按钮。

    下面我们就来详细介绍一下还如何实现这个悬浮按钮需求。

    创建悬浮操作按钮

    如何 SwiftUI 创建一个类似 Twitter App 中的悬浮按钮。

    实现悬浮操作按钮可能有很多方法,下面是我要实现按钮的一些简单需求,如下:

    • 悬浮按钮应该出现在屏幕的主要内容前面。
    • 悬浮按钮位于屏幕的右下角。
    • 悬浮按钮具有圆角形状,并在中心具有一个图标。
    • 悬浮按钮带有一个轻微的阴影。

    这是要实现悬浮按钮的所有行为。让我们逐步实现这些需求。

    在此之前,需要先创建并初始化一个屏幕用来承载这个悬浮按钮。

    以下是一个简单的列表视图,嵌套在导航视图和选项卡视图中,列表中显示了 item 加索引内容。

    并在菜单栏中添加了 Home 按钮和图标,核心代码如下:

    struct ContentView: View {
        var body: some View {
            TabView {
                NavigationStack {
                    List(0..<100) { i in
                        Text("Item \(i)")
                    }
                    .navigationTitle("Home")
                }
                .tabItem {
                    Label("Home", systemImage: "house")
                }
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15

    示例运行截图如下:

    悬浮按钮出现在屏幕的最前方

    首先,是需要实现需求中的第一步,悬浮按钮应该出现在屏幕的主要内容前面。

    要使视图出现在另一个视图前面,可以使用 ZStackoverlay 修饰符。

    在这种情况下,选择使用 ZStack,核心代码如下:

    struct ContentView: View {
        var body: some View {
            TabView {
                NavigationStack {
                    // 1
                    ZStack {
    
                        List(0..<100) { i in
                            Text("Item \(i)")
                        }
                        .navigationTitle("Home")
                        // 2
                        Button {
    
                            // 操作
                        } label: {
                            Image(systemName: "plus")
                        }
                    }
                }
                .tabItem {
                    Label("Home", systemImage: "house")
                }
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    1. 将内容视图(List)包装在 ZStack 中。
    2. 将一个按钮放在内容视图上。

    这将在列表视图上添加一个加号图像按钮。

    示例运行截图如下:

    悬浮按钮位于屏幕的右下角

    接着,是需要实现需求中的第二步,使按钮与内容视图对齐到右下角。

    这里可以在代码中使用 ZStack 的 alignment 参数将按钮与右下角对齐,核心代码如下:

    struct ContentView: View {
        var body: some View {
            TabView {
                NavigationStack {
                    // 1
                    ZStack(alignment: .bottomTrailing) {
    
                        List(0..<100) { i in
                            Text("Item \(i)")
                        }
                        .navigationTitle("Home")
    
                        Button {
                            // 操作
                        } label: {
                            Image(systemName: "plus")
                        }
                        // 2
                        .padding()
    
                    }
                }
                .tabItem {
                    Label("Home", systemImage: "house")
                }
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    1. ZStack(alignment: .bottomTrailing) 使较小的视图(Button)与较大的视图(List)底部右对齐。
    2. 我们还在按钮周围添加了填充,以使其不会过于靠近边缘。

    示例运行截图如下:

    将按钮对齐到屏幕的右下角

    使悬浮按钮呈现圆形

    接着,是需要实现需求中的第三步,使悬浮按钮具有圆角形状,并在中心具有一个图标。

    目前的情况位置是正确的,但外观还不符合要求。

    可以使用一系列修饰符使其变成圆形并加粗,核心代码如下:

    struct ContentView: View {
        var body: some View {
            TabView {
                NavigationStack {
                    ZStack(alignment: .bottomTrailing) {
                        List(0..<100) { i in
                            Text("Item \(i)")
                        }
                        .navigationTitle("Home")
    
                        Button {
                            // 操作
                        } label: {
                            // 1
                            Image(systemName: "plus")
    
                                .font(.title.weight(.semibold))
    
                                .padding()
    
                                .background(Color.pink)
    
                                .foregroundColor(.white)
    
                                .clipShape(Circle())
    
                        }
                        .padding()
                    }
                }
                .tabItem {
                    Label("Home", systemImage: "house")
                }
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 更改了字体样式,添加了填充,背景色和前景色,并将其裁剪成圆形。

    自定义按钮的外观

    添加阴影

    最后,是需要实现需求中的第四步,使悬浮按钮带有一个轻微的阴影。

    我们通过添加阴影为其增色,使其看起来像悬浮。

    SwiftUI 通过 shadow 修饰符内置了添加阴影的方法,核心代码如下:

    struct ContentView: View {
        var body: some View {
            TabView {
                NavigationStack {
                    ZStack(alignment: .bottomTrailing) {
                        List(0..<100) { i in
                            Text("Item \(i)")
                        }
                        .navigationTitle("Home")
    
                        Button {
                            // 操作
                        } label: {
                            Image(systemName: "plus")
                                .font(.title.weight(.semibold))
                                .padding()
                                .background(Color.pink)
                                .foregroundColor(.white)
                                .clipShape(Circle())
                                .shadow(radius: 4, x: 0, y: 4)
    
                        }
                        .padding()
                    }
                }
                .tabItem {
                    Label("Home", systemImage: "house")
                }
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    示例运行截图如下:

    添加阴影

    这就是在 SwiftUI 中创建悬浮操作按钮所需的全部步骤。

    总结

    在本文中,我们学习了如何在 SwiftUI 中创建一个悬浮操作按钮,它是 Android 和 Material Design 中常用的 UI 元素。通过逐步实现悬浮按钮的各个特性来完成这个过程。

    希望本文的内容对你在 SwiftUI 开发中有所帮助,能够轻松地实现漂亮的悬浮操作按钮,增强应用界面和用户交互体验。

  • 相关阅读:
    C++设计模式——Composite组合模式
    Juc并发编程12——2万字深入源码:线程池这篇真的讲解的透透的了
    AcrelEMS能效管理平台为高层小区用电安全保驾护航
    jenkins中添加sonnarqube与OWASP Dependency-Check
    NT68661-屏参升级-RK3128-开机自己升级屏参
    linux系统时钟控制
    运筹学基础【六】 之 运输问题
    什么是 BIO、NIO、AIO?
    第二证券|股票做短线要关注什么?
    Druid数据库连接池
  • 原文地址:https://blog.csdn.net/qq_36478920/article/details/134051378