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

SwiftUI视图显示和隐藏动画

SwiftUI最强大的功能之一是能够自定义视图显示和隐藏方式。以前,您已经了解了如何使用常规if条件有条件地包含视图,这意味着当条件更改时,我们可以从视图层次结构中插入或移除视图。...首先,我们添加一些可以操作的状态: @State private var isShowingRed = false 接下来,我们使用该状态作为显示矩形的条件: if isShowingRed {...200) } 最后,我们可以在按钮的点击事件中将isShowingRed在“true”和“false”之间切换: self.isShowingRed.toggle() 如果你运行程序,你会看到按下按钮显示或者隐藏红色方块...通过使用withAnimation()包装状态更改,我们可以获得SwiftUI的默认视图转换,如下所示: withAnimation { self.isShowingRed.toggle() }...一个有用的方法是不对称,它允许我们在显示视图时使用一个转换,在视图消失时使用另一个转换。

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

如何在 SwiftUI 视图显示应用图标和版本

在本文中,我将展示如何创建一个可访问的 SwiftUI 视图,既能显示应用图标和版本,又能在各种文本大小和外观下看起来都很好:获取应用图标构建视图的第一步是从主包中获取应用图标。...创建 SwiftUI 视图现在让我们将所有内容结合起来,创建一个 SwiftUI 视图显示应用图标和版本:AppVersionInformationView.swiftimport SwiftUIstruct...这些值通过我们之前创建的提供者传递给视图。我们在一个水平堆栈中显示应用图标和版本,间距为12点。我们在 Image 视图显示应用图标。...最终结果是一个在各种文本大小下都看起来很好的视图:在应用中显示版本信息视图Copy codeContentView.swiftimport SwiftUIstruct ContentView: View...在获取到应用图标和版本信息后,我们创建了一个 SwiftUI 视图来展示这些信息。该视图使用水平堆栈(HStack)布局,将应用图标和版本信息并排显示

10500

Ask Apple 2022 与 SwiftUI 有关的问答(下)

因此,如果你正在创建一个视图显示可滚动的内容,并可能进行选择操作,那么在 iOS 和 macOS 上使用 List 将有最好的体验。...自定义布局Q:我经常想根据列表中最长或最短的文字来布置各种小组件。鉴于动态文本大小在应用程序运行时可能会发生变化,衡量给定字体的文本大小的最佳方法是什么?A:你好!我们新的布局协议支持这个功能。...A:你最好的选择是使用 ScrollView 和 ScrollViewReader,并在 onAppear 或新内容进来时滚动到最底部的视图。我建议尝试旋转滚动视图。...Swiftcord[12] 的代码展示了如何在 SwiftUI 下实现倒置列表。阅读 优化在 SwiftUI List 中显示大数据集的响应效率[13] 一文,了解苹果工程师推荐的方法。...TextField 内容验证Q:如何实现一个只接受数字的 SwiftUI TextField,小数是允许的。A:向文本字段提供 FormatStyle 以实现自动将文本转换为各种数字。

14.7K30

Ask Apple 2022 与 SwiftUI 有关的问答(上)

是否有任何建议用来检测列表中的行选择,类似于 “NavigationLink”,但不导航到另一个视图(例如,显示 Sheet 或从列表中选择一个选项 )?...假设我们想创建一个类似于 iMessage 的视图,在那里你可以看到一个信息列表(与本例无关),在视图的底部有一个文本框。当用户点击文本字段时,键盘会在其工具栏中出现一个文本字段。...不过,在传统的 viewModel 意义上,我建议将视图( 结构本身 )作为视图模型。...这可能会导致一些不好的后果,例如使视图的可重用性降低,并将业务逻辑与 SwiftUI 视图的生命周期挂钩,这将使处理业务逻辑变得更加困难。简而言之,我们建议使用视图作为视图模型。...在有些情况下,我想根据视图是否折叠来做决定( 例如,如果展开,在详细视图显示一条信息,如果折叠,则显示一个警告或其他指示 )。

12.2K20

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

欢迎大家在 Discord 频道[2] 中进行更多地交流将某个视图在父视图中居中显示是一个常见的需求,即使对于 SwiftUI 的初学者来说这也并非难事。...即使文本宽度超出了 HStack 给出的建议宽度,但 HStack 在布局时,仍会保留其最小厚度,导致下图上方的文本无法充分利用矩形视图的宽度。解决方法为:Spacer(minLength: 0)。...image-20220829152914736将合成后的视图放置在某个可能会充满屏幕的视图的顶部或底部显示结果或者与你的预期不符 VStack { // Hello world 视图 1...解决的方法是:.background(.blue, ignoresSafeAreaEdges: []) ,排除掉希望忽略的安全区域。...每周也会对当周博客上的新文章以及在 Twitter 上发布的 Tips 进行汇总,并通过邮件列表的形式发送给订阅者。订阅下方的 邮件列表[10],可以及时获得每周的 Tips 汇总。

6.6K40

SwiftUI-开发iOS项目

Info.plist — 属性列表文件,包含项目的很多配置,如App名字、版本等 Preview Content — 这是一个文件夹,里面包含一个 Preview Assets.xcassets 启动流程...在初始化根视图控制器时会初始化ContentView中的View,显示出来 ContentView如何显示在屏幕上?...ContentView内部,有一个 body ,返回一个 Swift5.1 中新增的不透明的返回类型,意思就是返回某种 View,但是 body 不需要关心具体的内容 注意: body 不能返回很多 View 或返回任何...View ,此时Swift编译器都会报错,所以务必记住 body 必须始终返回一个 View 在 body 中的 Text("Hello SwiftUI"),表示创建了文本Hello SwiftUI...的标签 最后的结构体 ContentView_Previews,与ContentView类似,它专门用于在Xcode中显示视图预览。

4.7K10

SwiftUI 中的内容边距

今天,我们将了解 SwiftUI 引入的新内容边距概念以及它与安全区域的区别。创建示例让我们从一个简单的示例开始,演示带有一百个项目的列表。...") } }}如上例所示,我们将列表视图与一堆文本视图放在一起。...从字面上看,它是另一个安全区域,适应屏幕大小,但仅适用于文本内容。不幸的是,我们在 SwiftUI 中无法访问 readableContentGuide。...根据水平尺寸类别的不同(正常或紧凑),我们使用 contentMargins 视图修饰符来管理水平方向上的内容边距。在紧凑水平尺寸类别下,我们将内容移动了 200 个点,以便在大屏幕设备上居中显示。...总结本文介绍了 SwiftUI 中的内容边距管理,通过对比安全区域的概念,解释了内容边距的重要性。文章从创建示例开始,展示了在列表视图中如何处理内容边距的问题。

6910

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

这是个宝贵的机会,能让我认真体验一把 SwiftUI 并探索其内部工作原理。 起初项目工作良好,我对 SwiftUI 的表现可以说非常满意,我甚至创建了自己的修改器,以便更轻松地显示警报消息。...但在开始实现更复杂的检查器视图时,特别是涉及带有 / 不带步进器或颜色选择器的多个文本字段时,整个运行速度开始剧烈下降。...但每当 SwiftUI 更新检查器视图时(这种更新可能出现在移动过程中,甚至是在输入文本字段的时候),渲染速率都会下降到每秒 10 到 15 帧,而且相当不稳定。这显然让人无法容忍。...这些按钮只跟管理 SpriteKit 视图缩放的 @State 相关联。尽管几乎涉及任何其他数据,在界面更新前单击这些按钮,也会产生将近一秒钟的巨大延迟。...我刚开始以为是因为地图编辑器的 SpriteKit 主视图仍在后台渲染。所以我尝试在工作表显示出来后禁用渲染,但结果没有任何改变。 变更从一种环境传播至另一环境时,我也遇到了类似的延迟问题。

4.9K20

WWDC - SwiftUI - 初恋般的感觉

我们将使用SwiftUI框架来构建Landmark详情界面。 Landmarks利用stacks将图片和文本组合起来来进行视图布局。你需要引用MapKit框架头文件来创建一个地图视图。...左边没有了ViewController 多了sceneDelegate和ContentView 中间代码样式不一样了 右边多出一块预显示栏,很牛逼 默认情况下,SwiftUI视图文件声明两个结构...现在我们来玩玩预览: 如果画布没有展示出来,可以通过 Editor > Editor and Canvas 显示出来。 第四步 把Hello World更改为Hello SwiftUI!...第四步 手动修改代码,即添加.color(.green)把文本修改成绿色。 要自定义SwiftUI视图,你可以调用modifiers方法。...利用Stacks组合视图 我们创建了一个文本框用来显示landmark的详情信息,并且把这个文本控件放到头部。

3.8K10

SwiftUI 布局 —— 尺寸( 上 )

尺寸 —— 一个刻意被淡化的概念 SwiftUI 是一个声明式框架,提供了强大的自动布局能力。开发者几乎可以在涉及尺寸( 或很少涉及 )这一概念的情况下创建出漂亮、精美、准确的布局效果。...,省略的完整显示尺寸) ZStack 向 SwiftUI 的布局系统返回了自己的需求尺寸( 85.33 x 20.33,因为 ZStack 中仅有 Text 一个子视图,因此 Text 的需求尺寸便是...对于包含子视图视图来说( 例如 Text 这类的元视图 ),它们同样会提供接口供父视图来调用以向其传递建议尺寸并获取其需求尺寸。...因此,为了简化文字,我们在文章中会将父视图与具备布局能力的容器等同起来。 不过需要注意的是,在 SwiftUI 中,有一类视图是会在视图树上显示为父视图,但并不具备布局能力。...( 文本不折行、省略 ) 85.33 x 20.33( 上文例子中尺寸 ) 明确尺寸模式 如果建议宽度大于单行显示的需要,则需求宽度返回单行实现显示尺寸的宽度 85.33 ;如果建议宽度小于单行显示的需要则需求宽度返回建议尺寸的宽度

4.6K20

优化在 SwiftUI List 中显示大数据集的响应效率

本文将通过一个优化列表视图的案例,展现在 SwiftUI 中查找问题、解决问题的思路,其中也会对 SwiftUI 视图的显式标识、@FetchRequest 的动态设置、List 的运作机制等内容有所涉及...也就是当显示主界面菜单时,列表视图已经完成了实例的创建(可以通过在 ListEachRowHasID 的构造函数中添加打印命令得以证明),因此也不应是实例化列表视图导致的延迟。...在 SwiftUI 视图的生命周期研究[3] 一文中,我对 List 如何对子视图显示进行优化做了一定的介绍。...按照正常的逻辑,当进入列表视图 ListEachRowHasID 后 List 只应该实例化十几个 ItemRow 子视图 ( 按屏幕的显示需要 ),即便使用 scrollTo 滚动到列表底部,List...当仅通过 ForEach 来指定显示标识时,List 会对这些视图显示进行优化,仅在需要显示时才会对其进行实例化。

9.1K20

如何在 SwiftUI 中创建条形图

很容易将部分内容提取到子视图中,以便每个部分都很小且易于维护。从将包含 BarChartView 以及可能的其他文本或数据的视图开始。...以下列表数据被作为主视图的项目数据,每一条数据包含一个对(名称,值)。在真正的 app 里,这里的数据应该通过 ViewModel 从 model 里取数据。...向国家名称那样较长的文本显示出条形图下面的文本将条形图推到了线外。...文本视图的宽度被限制在条形图宽度的范围内,而且条形图的标签文本会被截断,条形图的文本视图也被限制在条形宽度的范围内,并且文本可以被隐藏起来。...SwiftUI 是一个很好的平台,用于创建视图和快速重构独立的子视图。在 SwiftUI 中构建条形图需要做一些工作,随着使用数据来试用条形图,可以确定更多的定制化。

5.1K10

掌握 SwiftUI 的 Safe Area

•keyboard与显示视图内容上的任何软键盘的当前范围相匹配的安全区域。...•all(默认)上述两种安全区域划分的合集 iOS 13 并没有提供键盘自动避让功能,开发者需要编写一些额外的代码来解决软键盘恰当遮盖视图(如 TextField )的问题。...safeAreaInsetList2 遗憾的是,在 iOS 15 之前,SwiftUI 并没有提供调整视图安全区的手段,如果我们想通过 SwiftUI 的手段创建一个自定义 Tabbar 时,列表中最后的内容将被...通过 safeAreaInset,我们可以缩小视图的安全区域,以确保所有内容都可以按预期显示。...下的表现 image-20211120172325088 iOS 15.2 之前的版本,safeAreaInset 对 List 和 Form 的支持有问题(ScrollView 表现正常),无法将列表最后的内容全部显示完整

7.5K31

AttributedString——不仅仅让文字更漂亮

// 设置属性——超链接 image-20211007165456612 在WWDC 2021之前,SwiftUI没有提供对属性字符串的支持,如果我们希望显示具有丰富样式的文本,通常会采用以下三种方式...: •将UIKit或AppKit控件包装成SwiftUI控件,在其中显示NSAttributedString•通过代码将NSAttributedString转换成对应的SwiftUI布局代码•使用SwiftUI...估计待日后SwiftUI提供更多的显示支持后会逐步补上其他暂不支持的属性。•uiKit可以在UIKit下被渲染的属性。...在属性字符串中,属性和文本可以被独立访问,AttributedString提供了三种视图方便开发者从另一个维度访问所需的内容。...Character和unicodeScalar视图 这两个视图提供了类似NSAttributedString的string属性的功能,让开发者可以在纯文本的维度操作数据。

3.8K40

SwiftUI 中用 Text 实现图文混排

欢迎大家在 Discord 频道[2] 中进行更多地交流SwiftUI 提供了强大的布局能力,不过这些布局操作都是在视图之间进行的。...一个和一组在 SwiftUI 中,Text 是使用频率最高的几个组件之一,几乎所有的文字显示操作均由其完成。随着 SwiftUI 版本的不断提升,Text 的功能也得到持续地增强。...如果 Text 视图无法在给定的建议宽度内显示全部的内容,在建议高度允许的情况下( 没有限制高度或显示行数 ),Text 会对内容进行换行处理,通过多行显示的方式保证内容的完整性。...动态类型( Dynamic Type )功能允许使用者在设备端设置屏幕上显示文本内容的大小。它可以帮助那些需要较大文本以提高可读性的用户,还能满足那些可以阅读较小文字的人,让更多信息出现在屏幕上。...,通过 SwiftUI 视图创建标签根据标签视图的尺寸创建空白占位图片在 Text 中添加占位图片,进行混排使用 overlay 将标签视图定位在 leadingTop 位置,覆盖于占位图片上TitleWithOverlay

4.2K30

SwiftUI - 百行代码变十行,Swift再创辉煌

原文作者:Cooci_和谐学习_不急躁 苹果开发者大会 WWDC 2019 在北京时间今天凌晨开幕。...开发者可以声明需要由一串文本输入框构成的组件 然后定义每一个输入框的字体对齐方式、字体样式、字体颜色。 这些代码比以往更加易懂,省时并易于维护。...例如,编写需要包含文本字段的项目列表时,开发者可以用代码描述每个字段的对齐方式、字体和颜色。代码也比以前更简单,更易于阅读。 ? 这种声明式风格非常适用于像动画这样复杂的元素。...// SwiftUI 示例代码 // 为视图的任何状态声明内容和布局。SwiftUI知道该状态何时发生变化,并更新视图的呈现以匹配该状态。...构建可复用的组件 将小的、单一职责的视图组合成更大、更复杂的接口。在为任何苹果平台设计的应用程序之间共享自定义视图

3K40

架构之路 (五) —— VIPER架构模式(一)

这与SwiftUI不同,在SwiftUI中,视图显示任何新视图。 这种分离来自“Uncle”Bob Martin的Clean Architecture paradigm。...路由器Router允许用户从旅行列表视图trip list view导航到旅行详细信息视图trip detail view。trip detail视图显示路线点列表以及路线地图。...用户将能够从此屏幕编辑路线点列表和旅行名称。 1. Setting Up the Trip Detail Screens 在显示细节屏幕之前,您需要创建它。...SwiftUI将所有目标视图声明为当前视图的一部分,并根据视图状态显示它们。...要将VIPER映射到SwiftUI视图现在负责显示/隐藏视图,路由router是一个目标视图生成器,presenter在它们之间进行协调。

17.4K10

SwiftUI 视图的生命周期研究

视图值树通常只保存当前布局、渲染所需的内容(个别情况下,会缓存少数参与布局、渲染的视图值),在 app 的生命周期中,随着 State 的变化而不断地变化。...比如在 List 和 LazyVStack 中,Cell 视图在创建之后即使滚动出屏幕参与布局与渲染,但 SwiftUI 仍会保留这些视图的数据,直到 List 或 LazyVStack 被销毁。...•在 List 和 LazyVStack 中,SwiftUI 出于效率的考虑,即使 Cell 视图移出显示范围,它的视图仍将保留在视图值树上(视图仍将存续)。...因此,当 Cell 视图出现在显示范围内(影响容器布局)会触发 onAppear,移出显示范围(不影响容器布局)会触发 onDisappar。在其存续期内可以反复触发。...开发者即使不了解文本上述的内容,也可以让 SwiftUI 的代码在日常中发挥出不错的效率。但如果能够对视图的生命周期有更深入的了解,将可以帮助开发者在一些特定的场合提高代码的执行效率。

4.3K30
领券