ActionOver 项目教程

ActionOver 项目教程

ActionOverA custom SwiftUI modifier to present an ActionSheet or a Popover menu项目地址:https://gitcode.com/gh_mirrors/ac/ActionOver

1. 项目的目录结构及介绍

ActionOver 项目的目录结构如下:

ActionOver/
├── ActionOver.swift
├── ContentView.swift
├── README.md
├── LICENSE
└── Package.swift

目录结构介绍

  • ActionOver.swift: 包含 ActionOver 自定义 SwiftUI 修饰符的实现。
  • ContentView.swift: 包含示例应用程序的主视图。
  • README.md: 项目的说明文档。
  • LICENSE: 项目的许可证文件,采用 MIT 许可证。
  • Package.swift: Swift 包管理器的配置文件。

2. 项目的启动文件介绍

项目的启动文件是 ContentView.swift,它定义了应用程序的主视图。以下是 ContentView.swift 的代码片段:

import SwiftUI

struct ContentView: View {
    @State private var showActionOver = false

    var body: some View {
        VStack {
            Button(action: {
                self.showActionOver = true
            }) {
                Text("Show Action Over")
            }
        }
        .actionOver(
            presented: $showActionOver,
            title: "Action Over",
            message: "Choose an option",
            buttons: [
                ActionOverButton(title: "Option one", type: .normal, action: {}),
                ActionOverButton(title: "Option two", type: .normal, action: {}),
                ActionOverButton(title: "Delete", type: .destructive, action: {}),
                ActionOverButton(title: nil, type: .cancel, action: nil)
            ],
            ipadAndMacConfiguration: IpadAndMacConfiguration(anchor: nil, arrowEdge: nil)
        )
    }
}

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

启动文件介绍

  • ContentView: 定义了应用程序的主视图,包含一个按钮,点击按钮后会显示 ActionOver 菜单。
  • @State private var showActionOver: 一个状态变量,用于控制 ActionOver 菜单的显示。
  • .actionOver: 使用自定义的 ActionOver 修饰符来显示 ActionSheet 或 Popover 菜单。

3. 项目的配置文件介绍

项目的配置文件是 Package.swift,它用于定义 Swift 包管理器的依赖项和目标。以下是 Package.swift 的代码片段:

// swift-tools-version:5.3
import PackageDescription

let package = Package(
    name: "ActionOver",
    platforms: [
        .iOS(.v13),
        .macOS(.v10_15)
    ],
    products: [
        .library(
            name: "ActionOver",
            targets: ["ActionOver"]
        )
    ],
    dependencies: [],
    targets: [
        .target(
            name: "ActionOver",
            dependencies: []
        ),
        .testTarget(
            name: "ActionOverTests",
            dependencies: ["ActionOver"]
        )
    ]
)

配置文件介绍

  • name: 包的名称。
  • platforms: 支持的平台和版本。
  • products: 定义包提供的产品,这里是一个库。
  • dependencies: 包的依赖项,这里没有外部依赖。
  • targets: 定义包的目标,包括主目标和测试目标。

通过这些配置,开发者可以使用 Swift 包管理器轻松地将 ActionOver 集成到他们的项目中。

ActionOverA custom SwiftUI modifier to present an ActionSheet or a Popover menu项目地址:https://gitcode.com/gh_mirrors/ac/ActionOver

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

袁泳臣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值