首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SwiftUI使用UIKit视图

SwiftUI使用UIKit视图 如想获得更好的阅读体验可以访问我的博客www.fatbobman.com,或点击下方的阅读原文 已迈入第三个年头的SwiftUI相较诞生初始已经提供了更多的原生功能...本文将通过对UITextField的包装来讲解以下几点: •如何在SwiftUI使用UIKit视图•如何让你的UIKit包装视图具有SwiftUI风格•在SwiftUI使用UIKit视图需要注意的地方...如果你已经对如何使用UIViewRepresentable有所掌握,可以直接从SwiftUI风格化部分阅读 基础 在具体演示包装代码之前,我们先介绍一些与在SwiftUI使用UIKit视图有关的基础知识...使用该app你会发现原来SwiftUI提供了如此多的功能。...学会使用很容易,但想用好确实有一定的难度。在UIKit视图SwiftUI视图之间共享可变状态和复杂的交互通常相当复杂,需要我们在这两种框架之间构建各种桥接层。

8.1K20
您找到你想要的搜索结果了吗?
是的
没有找到

避免 SwiftUI 视图的重复计算

符合 DynamicProperty 协议的属性包装器 几乎每一个 SwiftUI使用者,在学习 SwiftUI 的第一天就会接触到例如 @State、@Binding 这些会引发视图更新的属性包装器...当 SwiftUI视图视图树上删除时,会一并完成对 SwiftUI 数据池以及关联的清理工作。如此,使用 State 包装的变量,其存续期将与视图的存续期保持完全一致。...并且 SwiftUI 会在其变化时自动更新( 重新计算 )对应的视图SwiftUI 上有一个困扰了不少人的问题:为什么无法在视图的构造函数中,更改 State 包装的变量值?...创建新实例 将新实例与 SwiftUI 当前使用的实例进行比对 如实例发生变化,用新实例替换当前实例,对实例的 body 求值,并用新的视图值替换老的视图视图的存续期不会因为实体的更替有所改变 由于...当触发器接收到事件后,无论其是否更改当前视图的其他状态,当前的视图都会被更新。

9.1K81

SheetKit——SwiftUI模态视图扩展库

SheetKit——SwiftUI模态视图扩展库 新写了个的SwiftUI Sheet扩展库,添加对可变高度Sheet的支持。...开发SheetKit的主要原因: •便于Deep link的调用SwiftUI提供了onOpenURL方法让应用程序可以非常轻松的响应Deep Link。但在实际使用中,情况并不如预期。...•模态视图的集中管理SwiftUI通常采用.sheet来创建模态视图,对于简单的应用来说,这种形式非常直观,但如果应用程序的逻辑比较复杂、需要的模态视图众多,则上述方式就会让代码显得十分混乱,不易整理。...支持两种方式:直接使用SheetKit的实例、在视图使用环境值。...在SwiftUI3.0中,已经可以使用原生API生成各种毛玻璃效果了。但只有将模态视图的背景设置为透明,毛玻璃效果才能显现出来。

2.8K20

用NavigationViewKit增强SwiftUI的导航视图

用NavigationViewKit增强SwiftUI的导航视图 如果想获得更好的阅读体验,请访问我的博客 www.fatbobman.com[1] 最近一直在为我的iOS健康管理app健康笔记3.0[...由于SwiftUI原生提供的导航手段能力有限,因此在之前的版本中,NavigationView总是使用的不是那么的顺手。...该扩展遵循以下几个原则: •非破坏性任何新添加的功能都不能影响当前SwiftUI提供的原生功能,尤其是不能影响例如Toolbar、NavigationLink在NavigationView中的表现•尽可能便于使用仅需极少的代码便可使用新增功能...目前常用的解决方案有两种: •重新包装UINavigationController好的包装确实可以使用到UINavigationController提供的众多功能,不过非常容易同SwiftUI中的原生方法相冲突...视图中支持SwiftUI原生的所有定义,例如toolbar、navigationTitle等。 目前在启用转场动画时,title和toolbar会在转场动画后才显示,观感稍有不足。日后尝试解决。

3.2K20

SwiftUI视图的显示和隐藏动画

SwiftUI最强大的功能之一是能够自定义视图的显示和隐藏方式。以前,您已经了解了如何使用常规if条件有条件地包含视图,这意味着当条件更改时,我们可以从视图层次结构中插入或移除视图。...转换控制插入和删除的方式,我们可以使用内置转换,以不同的方式组合它们,甚至创建完全自定义的转换。...通过使用withAnimation()包装状态更改,我们可以获得SwiftUI的默认视图转换,如下所示: withAnimation { self.isShowingRed.toggle() }...看起来不错,但是我们可以使用transition()修饰符做得更好。...一个有用的方法是不对称,它允许我们在显示视图使用一个转换,在视图消失时使用另一个转换。

4.4K30

SwiftUI 视图的生命周期研究

当 State 发生变化后,SwiftUI 会生成一棵新的视图值树(Source of truth 没有发生变化的节点,不会重新计算,直接使用旧值),并同老的视图值树进行比对,SwiftUI 将对其中有变化的部分重新布局渲染...•在 NavigationView 中,如果在 NavigationLink 中使用了静态的目标视图SwiftUI 将会为所有的目标视图创建实例,无论是否访问。...•除了使用属性包装器外,SwiftUI 还为视图还提供了 onReceive、onChange、onOpenURL、onContinueUserActivity 等方式进行依赖注册。...•下文中会提到,在视图值树的视图生命周期内,无论创建多少个实例都只会保留一份依赖项副本。当使用新实例时,SwiftUI 仍会将新的实例同原有的依赖项关联起来。...在前文的视图值树介绍中我们提到,当 SwiftUI 重建该树时,如果树上某个节点(视图)的 Source of truth 没有发生变化,将不重新计算,直接使用旧值。

4.2K30

SwiftUI:alert() 和 sheet() 与可选值一起使用

SwiftUI有两种创建警报和表单的方式,到目前为止,我们仅使用一种方法:绑定到布尔值,该布尔值在变为 true 时显示 Alert 或 Sheet。...第二种方法并不经常使用,但是在您需要的时候它确实有用:您可以使用可选的Identifiable对象作为条件,并且当该对象具有值时将显示 Alert 或Sheet 。...= nil 现在,我们可以更改ContentView的body,以便在点击其文本视图时将selectedUser设置为一个值,然后再为selectedUser提供值时使用alert(item:)显示警报...出现提示“Taylor Swift”的警报。解除警报后,SwiftUI会将selectedUser设置为nil。 这似乎是一个简单的功能,但是比其他功能更简单,更安全。...参考 Alert弹窗 SwiftUI:ActionSheet 弹窗 SwiftUI:Sheet 视图 译自 Using alert() and sheet() with optionals

2.4K40

SwiftUI 中用 zIndex 调整视图显示顺序

本文将对 SwiftUI 的 zIndex 修饰符做以介绍,包括:使用方法、zIndex 的作用域、通过 zIndex 避免动画异常、为什么 zIndex 需要设置稳定的值以及在多种布局容器内使用 zIndex...访问我的博客 www.fatbobman.com[1] 可以获得更好的阅读体验 zIndex 修饰符 在 SwiftUI 中,开发者使用 zIndex 修饰符来控制重叠视图间的显示顺序,具有较大 zIndex...在没有指定 zIndex 值的时候,SwiftUI 默认会给视图一个为 0 的 zIndex 值。...zIndex 值相同(比如全部使用默认值 0 ),SwiftUI 会按照布局容器的布局方向( 视图代码在闭包中的出现顺序 )对视图进行绘制。...总结 zIndex 使用简单,效果明显,为我们提供了从另一个维度来调度、组织视图的能力。

1.7K30

SwiftUI 视图中打开 URL 的若干方法

访问我的博客 www.fatbobman.com[1] 可以获得更好的阅读体验 本文将介绍在 SwiftUI 视图中打开 URL 的若干种方式,其他的内容还包括如何自动识别文本中的内容并为其转换为可点击链接...image-20220520182722773 SwiftUI 1.0( iOS 13、Catalina ) 在视图中,开发者通常需要处理两种不同的打开 URL 的情况: 点击一个按钮( 或类似的部件...SwiftUI 2.0( iOS 14、Big sur ) SwiftUI 2.0 为第一个场景提供了相当完美的原生方案,但仍无法通过原生的方式来处理第二种场景。...在 SwiftUI 中,采用类似逻辑的还有 onSubmit ,有关 onSubmit 的信息,请参阅 SwiftUI TextField 进阶 —— 事件、焦点、键盘[6]。...视图中打开 URL 的几种方法,不过读者应该也能从中感受到 SwiftUI 三年来的不断进步,相信不久后的 WWDC 2022 会为开发者带来更多的惊喜。

7.6K31

SwiftUI 中实现视图居中的若干种方法

欢迎大家在 Discord 频道[2] 中进行更多地交流将某个视图在父视图中居中显示是一个常见的需求,即使对于 SwiftUI 的初学者来说这也并非难事。...().fill(.clear)在使用 SwiftUI 进行开发的过程中,Color、Rectangle 等经常被用来实现对容器的等分操作。...不过除非矩形的尺寸明确,否则里外都需要使用 GeometryReader ,实现将过于烦琐。总结本文选取了一些有代表性的解决方法,随着 SwiftUI 功能的不断增强,会有越来越多的手段可供使用。...我为本文这种通过多种方法来解决一个问题的方式添加了【小题大作】标签,目前使用该便签的文章还有:在 Core Data 中查询和使用 count 的若干方法[6]、在 SwiftUI 视图中打开 URL.../[7] 在 SwiftUI 视图中打开 URL 的若干方法: https://www.fatbobman.com/posts/open_url_in_swiftUI/[8] Twitter: https

6.6K40

构建稳定的预览视图 —— SwiftUI 预览的工作原理

作为 SwiftUI 最引人注目的功能之一,预览功能吸引了不少开发者初次接触 SwiftUI。然而,随着项目规模的增长,越来越多的开发者发现预览功能并不如最初想象的那么易用。...由于预览崩溃的次数和场景的增加,一些开发者已经视预览为 SwiftUI 的缺点之一,并对其产生了排斥感。 预览功能真的如此不堪吗?我们当前使用预览的方式真的妥当吗?...欢迎大家在 Discord 频道[2] 中进行更多地交流 让预览崩溃的一段视图代码 不久前,Toomas Vahter 写了一篇博客 Bizarre error in SwiftUI preview[3...了解了问题所在,我们还可以使用其他两种方式来解决之前的代码无法在预览中使用的问题。 方法一 将 Item 从 ContentView 中移出来,放置到与 ContentView 同级的代码位置。...但是,这也可能导致无法正常编译的情况发生(例如本文中的例子) 预览是以预览衍生文件作为入口的,开发者必须在预览代码中为预览视图提供足够的上下文信息( 例如注入所需的环境对象 ) 总的来说,Xcode 预览功能虽然在视图开发流程中极为方便

42010

SwiftUI:Alert弹窗

如果发生重要事件,通知用户的一种常见方法是使用警报Alert弹窗-根据您的需要,该弹出窗口包含标题,消息和一个或两个按钮。 但是请考虑一下:何时应该显示警报以及如何显示Alert?...视图是我们程序状态的函数,Alert也不例外。因此,我们不用说“显示警报”,而是创建警报并设置显示警报的条件。...相反,我们创建一些状态来跟踪警报是否显示,如下所示: @State private var showingAlert = false 然后,我们将警报附加到用户界面的某处,告诉它使用该状态来确定是否显示警报...SwiftUI将观察showingAlert,并在它变为true时立即显示警报。...仔细看看alert()修饰符: .alert(isPresented: $showingAlert) 这是另一种双向数据绑定,这是因为SwiftUI会在警报解除后自动将showingAlert设置为false

5.3K20

我庆幸果断放弃了SwiftUI:它还不够成熟

新框架使用声明性范例,让开发者用更少的代码编写相同的 UI。 SwiftUI 的愿景是降低开发 iOS 门槛,吸引更多开发者、丰富 iOS 的业态。...这是个宝贵的机会,能让我认真体验一把 SwiftUI 并探索其内部工作原理。 起初项目工作良好,我对 SwiftUI 的表现可以说非常满意,我甚至创建了自己的修改器,以便更轻松地显示警报消息。...首先,由可选对象提供的视图在每次重绘时都是在完全重新创建。我虽然通过缓存稍稍提升了性能表现,但实际体验仍然非常糟糕。事实证明,SwiftUI 检查器视图就是没法提供合理的重绘速度。...我在网上查找了解决方案,最后编写了一个延迟版本的 ObservableObject,由它来强制每秒只发布一次更改(参见以下代码)。...但这会导致检查器中的值出现延迟,因此在地图编辑器的交互过程中(比如使用移动工具时)结果不准确,所以效果还是称不上完美。 但我觉得这可能只是个独立问题,并不能因此把 SwiftUI 一棒子打死。

4.8K20

使用 SwiftUI 的 Eager Grids

介绍 早在 2020 年,我们就拥有了在 SwiftUI(LazyVGrid 和 LazyHGrid)中绘制网格的新视图控件。两年后,我们又获得了另一种在网格(Grid)中显示视图视图控件。...单元格视图仅在它们被滚动时创建,并且在它们滚动时停止计算。 这篇文章的主题 Eager Grids 正好相反。SwiftUI 不在乎它们是在屏幕上还是在屏幕外。所有视图都被同等对待。...当没有布局容器存在时,SwiftUI 会隐式使用 VStack。...您使用 Grid 容器视图,然后通过对 GridRow 容器内的单元格视图进行分组来定义其行。...该应用程序可让您以交互方式使用所有这些网格参数。当您更改网格时,该应用程序还将向您显示生成您创建的网格的代码。 整个应用程序位于一个 swift 文件中,因此只需几秒钟即可完成设置。

4.3K20

使用 SwiftUI 创建万花尺

为了完成一些真正意义上的绘图工作,我将带您通过创建一个简单的带 SwiftUI 的 spirograph。...我会解释的,但是如果你不感兴趣的话,跳过这一章是完全可以的——这只是为了好玩,这里没有介绍新的 Swift 或 SwiftUI。 我们的算法有四个输入: 内圈的半径。 外圈的半径。...我们所有的输入以整数形式提供时效果最好,但是在绘制轮盘赌时,我们需要使用CGFloat,因此我们还将创建输入的CGFloat副本。...else { path.addLine(to: CGPoint(x: x, y: y)) } } return path 我意识到这有很多繁重的数学,但回报即将到来:我们现在可以在视图使用该形状...在我结束之前,我想提醒你,这里使用的参数方程是数学标准,而不是我刚刚发明的东西——我真的去百度了关于 hypotrochoids[1] 的页面,并将它们转换为 Swift。

64210
领券