跳到主要内容

22 篇博文 含有标签「SwiftUI」

查看所有标签

SwiftUI 中的内容边距

· 阅读需 5 分钟

SwiftUI 引入了一组视图修饰符,允许我们高效地管理视图中的安全区域。在许多情况下,安全区域是你希望放置内容的地方。今天,我们将了解 SwiftUI 引入的新内容边距概念,以及它与安全区域有何不同。

在 SwiftUI 中检测按键事件。

· 阅读需 7 分钟
GoSwiftUI
goswiftui.com

在 SwiftUI 中检测按键事件允许你响应键盘键,如回车(输入)、shift、command 等。虽然大多数 Mac 应用程序使用键盘事件,但你必须考虑为 iPad 应用程序添加支持,因为可以使用外部键盘。

避免 SwiftUI 任务阻塞 MainActor

· 阅读需 5 分钟
GoSwiftUI
goswiftui.com

我发现很容易不小心阻塞了 MainActor,并且因为一个我以为在后台线程上的长时间运行任务而导致用户界面挂起。这里有一个最近的例子。

用户界面挂起

Apple 建议不要在主线程上运行长期运行的任务。阻塞主线程超过100 毫秒,用户会注意到无响应或挂起的用户界面。

用SwiftUI轻松使用SFSafariViewController实现在APP里打开网页

· 阅读需 7 分钟
GoSwiftUI
goswiftui.com

SFSafariViewController 可用于让用户在应用内而非外部浏览器中打开网页。虽然该视图控制器在 UIKit 中运行良好,但在 SwiftUI 应用中让其正常工作可能具有挑战性。

每当你遇到只有 UIKit 解决方案可用的情况时,你想知道如何编写一个包装器并使 UIKit 类对 SwiftUI 视图可用。最好的情况是,它是可重用的,以便稍后可以重复使用它。让我们深入了解吧!

在SwiftUI中使用CoordinateSpace实现视差标题效果

· 阅读需 6 分钟
GoSwiftUI
goswiftui.com

在移动和 Web 应用程序中,视差标题是一种流行的设计模式,可以创建视觉上令人惊叹的界面。通过在用户滚动时以不同的速度移动内容,视差标题可以创建深度和动态的错觉。

在本博客文章中,我们将讨论如何使用 SwiftUI 实现视差标题。我们将使用.named(coordinateSpace)修饰符创建一个坐标空间,用于计算标题在用户滚动时的位置。

优化 SwiftUI 支持多平台代码

· 阅读需 4 分钟
GoSwiftUI
goswiftui.com

对于使用 SwiftUI 的多平台项目,它确实可以显著加快为多个平台开发的速度。然而,由于苹果的各个平台之间存在足够的差异,因此最终你的代码库将充斥着#if os()判断。

SwiftUI 自定工具栏

· 阅读需 5 分钟
GoSwiftUI
goswiftui.com

工具栏API是我在SwiftUI中最喜欢的API之一。它允许您以非常明确的方式定义工具栏及其项目,并在不同的平台上表现不同。下一代SwiftUI框架为我们带来了更多自定义工具栏的方法。下面,我们将了解 SwiftUI 中新的工具栏 API。

使用 SwiftUI 为 iOS16 实现锁屏小组件

· 阅读需 5 分钟
GoSwiftUI
goswiftui.com

iOS 要求最多的功能之一是可定制的锁屏。最后,我们在最新的iOS 16上得到了它。我们可以用一目了然的小组件填充我们的锁屏。实现锁屏小组件很简单,因为它的API与主屏幕小组件共享相同的代码。下面我们将学习如何为我们的应用程序实现锁屏小组件。

SwiftUI 中实现共享跨平台(iOS/macOS)代码

· 阅读需 3 分钟
GoSwiftUI
goswiftui.com

在SwiftUI中构建应用程序的主要吸引力在于能够跨平台共享 UI 代码,尤其是 iOS 和 macOS。它并不完美,您经常需要进行一些#if os()检查,但是当它起作用时,它确实很棒。在 SwiftUI 出现之前,您已经可以在 iOS 和 macOS 之间共享大量(非 UI)代码。许多系统框架在两个平台上都可用,例如FoundationCore Data。偶尔会存在 API 差异,但它们很少会带来很大的负担。

在开发跨平台 SwiftUI 应用程序时,最大的问题是当您需要在 macOS上使用AppKit和在 iOS上使用UIKit时。通常,您需要的 API(因为 SwiftUI 中没有它们)完全不同。但是,有时 API几乎相同,但只是不同,以至于需要分支到特定于平台的代码路径。一个很好的例子是UIPasteboard在 iOS 和NSPasteboardmacOS 上。

在我正在开发的这个跨平台 SwiftUI 应用程序中,我希望允许用户从表格视图中复制一些文本。两个平台共享 UI 代码,但不共享底层复制功能——因为我们需要在 macOS 上使用 AppKit,在 iOS 上使用 UIKit。但我想保持调用站点的复制操作代码干净,无需进行大量#if os()检查。为此,您可以巧妙地使用typealias.

使用 SwiftUI/UIKit 实现 iOS 应用密码自动填充

· 阅读需 4 分钟
GoSwiftUI
goswiftui.com

了解如何在 SwiftUI 和 UIKit 实现 Apple 的密码自动填充。

Apple 的密码自动填充功能允许用户在不同设备上登录同一个帐户,而无需记住他们的凭据。

例如,在 Web 应用程序中注册时,用户可以生成密码并将凭据保存在他们的 iCloud 钥匙串中。当他们在某个时候运行本机应用程序以访问同一帐户时,该应用程序会在密码 QuickType 栏中建议为网站存储的凭据。在用户进行身份验证后,假设使用 Face ID,系统会预先填写凭据 - 因此无需重新输入它们。