SheetKit——SwiftUI模态视图扩展库 新写了个的SwiftUI Sheet扩展库,添加对可变高度Sheet的支持。...•模态视图的集中管理SwiftUI通常采用.sheet来创建模态视图,对于简单的应用来说,这种形式非常直观,但如果应用程序的逻辑比较复杂、需要的模态视图众多,则上述方式就会让代码显得十分混乱,不易整理。...因此,在此种情况下,通常我们会将所有的模态视图集中管理起来,统一调用。请参阅我之前的文章——在SwiftUI中,根据需求弹出不同的Sheet[3]。...•新的半高模态视图在WWDC 2021中,苹果为大家带来了期待已久的半高模态视图。或许推出的比较仓促,这种很受欢迎的交互方式并没有提供SwiftUI版本,仅支持UIKit。...interactiveDismissDisabled SwiftUI 3.0的interactiveDismissDisabled加强版,在通过代码控制是否允许手势取消的基础上,增加了当用户使用手势取消时可以获得通知的能力
本文将通过一段可复现的“灵异代码”,对 State 注入优化机制、模态视图( Sheet、FullScreenCover )内容的生成时机以及不同上下文( 相互独立的视图树 )之间的数据协调等问题进行探讨...与大多数的 View Extension 和 ViewModifier 不同,在视图中,通过 .sheet 或 .fullScreenCover来声明的模态视图内容代码的闭包,只会在显示模态视图的时候才会被调用...代码块中的 SheetInitMonitorView 没有任何输出( 意味着闭包没有被调用 ),只有在模态视图进行显示时,SwiftUI 才执行 .sheet 闭包中的函数,创建 Sheet 视图。...也就是说 Sheet 中的视图与原有视图分别处于不同的上下文中。在 SwiftUI 早期的版本中,对于分别位于不同上下文的独立的视图树,开发者需要显式为 Sheet 视图树注入环境依赖。...事实上,使用 @StateObject 相当于在 vm.n 发生变化后,强制视图重新计算。
去年9月,我在文章【在SwiftUI中制作可以控制取消手势的Sheet】[3]中介绍了健康笔记2.0[4]版本的Sheet控制实现方法。...在今年推出的SwiftUI 3.0版本中,苹果添加了一个新的View扩展:interactiveDismissDisabled,该扩展实现了上面的第一个要求——通过代码控制是否允许手势取消Sheet。...原理 委托 从iOS 13开始,苹果调整了模态视图的委托协议(UIAdaptivePresentationControllerDelegate)。...") } }} dismissSheet2 本文的代码可以在Gist[9]上查看 总结 SwiftUI已经诞生两年多了,开发者也已经逐渐掌握为SwiftUI添加新功能的各种技巧。...中制作可以控制取消手势的Sheet】: https://www.fatbobman.com/posts/swiftui-dismiss-sheet/ [4] 健康笔记2.0: https://www.fatbobman.com
这些控件基本上都是对 UIkit(AppKit)的二次包装。Sheet执行下面的代码,你可以清楚地看到,在通过手势取消 Sheet 时,与其关联的状态是在 Sheet 完成取消动画后才发生了改变。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛或聊天室里看到不少的开发者都在寻找解决方法。...它的复现条件非常简单:在真机上测试( 模拟器上不容易复现 )点击 “GO” 按钮进入下一层视图点击 “Show Sheet” 按钮弹出 Sheet通过下滑手势取消 Sheet在 Sheet 取消后(动画结束时...它的复现条件如下:iOS 16 系统,在真机或模拟器上测试点击视图列表中的按钮,可以进入下一级视图。...通过自定义返回按钮以及扩展 UINavigationController 的方式,实现了在禁用 Back 按钮后仍支持手势返回,并先修改状态后再进行视图响应。
100% 基于 SwiftUI 开发,目前支持三个平台: iPhone、iPad 和 macOS。使用者可以通过它来浏览电影信息,包括正在上映以及即将上映的影片。...从另一个角度来看,用 SwiftUI 编写的代码,尽管大部分可以运行在不同的平台上,但有一部分则只能运行在特定平台上,而且往往这部分有平台限定的功能,最能体现平台所具有的特点和优势。...但是,如果开发者不能理解 SwiftUI 的这个“限制”,并提前做一些准备工作,可能会为之后的多平台开发工作带来一些隐患和增加不必要的工作量。以“电影猎手”的 iPad 版本为例。...当我们将“电影猎手”从 iPhone 移植到 iPad 或 Mac 上时,除了屏幕可用空间更大之外,另一个显着的变化是使用者可以同时打开多个窗口,并可以在不同的窗口中对“电影猎手”进行独立的操作。...然而,如果我们直接将尚未进行多屏适配的 iPhone 版本的“电影猎手”运行于 iPad 上,会发现尽管可以同时开启多个“电影猎手”窗口,但所有的操作都是同步的,也就是在一个窗口中进行的操作同时会体现在另一个窗口中
100% 基于 SwiftUI 开发,目前支持三个平台: iPhone、iPad 和 macOS。 使用者可以通过它来浏览电影信息,包括正在上映以及即将上映的影片。...从另一个角度来看,用 SwiftUI 编写的代码,尽管大部分可以运行在不同的平台上,但有一部分则只能运行在特定平台上,而且往往这部分有平台限定的功能,最能体现平台所具有的特点和优势。...但是,如果开发者不能理解 SwiftUI 的这个“限制”,并提前做一些准备工作,可能会为之后的多平台开发工作带来一些隐患和增加不必要的工作量。 以“电影猎手”的 iPad 版本为例。...当我们将“电影猎手”从 iPhone 移植到 iPad 或 Mac 上时,除了屏幕可用空间更大之外,另一个显着的变化是使用者可以同时打开多个窗口,并可以在不同的窗口中对“电影猎手”进行独立的操作。...然而,如果我们直接将尚未进行多屏适配的 iPhone 版本的“电影猎手”运行于 iPad 上,会发现尽管可以同时开启多个“电影猎手”窗口,但所有的操作都是同步的,也就是在一个窗口中进行的操作同时会体现在另一个窗口中
在 iPhone 上可能看起来很好,但是在 iPad 上,它看起来非常奇怪,因为它将所有文本放在了前导边缘,并保持屏幕中央为空白。...从字面上看,它是另一个安全区域,适应屏幕大小,但仅适用于文本内容。不幸的是,我们在 SwiftUI 中无法访问 readableContentGuide。...适配 iPad我们可以通过增加 iPad 上的安全区域来解决此问题,如下所示:struct ContentView: View { @Environment(\.horizontalSizeClass...200 : 0) } }}我们通过使用 horizontalSizeClass 环境值和 safeAreaPadding 视图修饰符,将内容移动到了 iPad 上的中心。...随后,通过介绍 UIKit 中的 readableContentGuide 布局指南以及 SwiftUI 中的 safeAreaPadding 视图修饰符,展示了在 iPad 上适配内容边距的方法。
视图变化在前、状态变化在后 在 SwiftUI 中,某些可编程控件在执行一定的操作时,会先更新视图,待视图变化完成后再修改与其对应的状态。这些控件基本上都是对 UIkit(AppKit)的二次包装。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死 这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛或聊天室里看到不少的开发者都在寻找解决方法。...它的复现条件非常简单: 在真机上测试( 模拟器上不容易复现 ) 点击 “GO” 按钮进入下一层视图 点击 “Show Sheet” 按钮弹出 Sheet 通过下滑手势取消 Sheet 在 Sheet 取消后...它的复现条件如下: iOS 16 系统,在真机或模拟器上测试 点击视图列表中的按钮,可以进入下一级视图。...通过自定义返回按钮以及扩展 UINavigationController 的方式,实现了在禁用 Back 按钮后仍支持手势返回,并先修改状态后再进行视图响应。
然后,使用 URL 来决定 App clip card 上显示什么数据 (App clip card 是一个我们调用后在底部弹出的 Sheet 视图)。...增强用户体验 App clip 不会显示在主屏幕上,并且用户无法以管理 App 的方式对其进行管理。相反,一段时间不活动后,系统会从设备中删除 App clip 。...Keep Your App Clip Small App clip 的大小必须不超过10 MB,才能提供即时启动。如果可能,将您的应用剪辑保持在此限制以下。...App clip 的可用框架 App clip 可以使用 SwiftUI 和 UIKit ,并且可以访问与完整应用程序相同的框架。...•App extensions•自定义和设置;例如,创建 settings bundle•资料移交和文件开启•IAP 和 支付卡配置•低级Unix功能;例如,BSD通知•iPad 的分屏•注册自定义 URL
提供苹果实时榜单查询,包含 iOS 和 iPad 的热门免费榜、热门付费榜、畅销榜,还有新上架榜、新上架免费榜、新上架付费榜等。...2.1 排行榜 首先,App Store 的榜单有很多,包含 iOS 和 iPad 的热门免费榜、热门付费榜、畅销榜,还有新上架榜、新上架免费榜、新上架付费榜等,我们都实现了这些榜单。...比如,SwiftUI 还不支持 WebView,所以用 SFSafariViewController 桥接的 View 在 SwiftUI 组件中显示会异常。...- Stack Overflow 另外,就是苹果 API 的坑,接口返回的字段 im:id、im:bundleId,包含冒号,让人怀疑人生!最后,通过自定义键值名,解决了解析映射的问题。...App,可以开始使用 SwiftUI 来开发,毕竟原生的体验和原生的组件,用户起来也很快乐。
预览可以直接在连接的苹果设备上运行,包括iPhone,iPad,iPod touch,Apple Watch和Apple TV,允许开发人员查看应用程序如何响应Multi-Touch,或者在界面构建过程中与摄像头和车载传感器实时工作...它还具有动画、物理和空间音频功能,开发人员可以使用新的RealityKit Swift API利用RealityKit的功能。...轻松让iPad应用程序支持Mac 新的工具和API使iPad应用程序更容易上传到Mac。...现在Core ML支持100多个模型层,应用程序可以使用最先进的模型,以前所未有的方式提供深刻理解视觉,自然语言和语音的体验。 开发人员第一次可以使用模型个性化更新设备上的机器学习模型。...具有不同数据集的多模型训练可以与对象检测,活动和声音分类等新类型的模型一起使用。
SwiftUI 与 Core Data —— 问题[1]SwiftUI 与 Core Data —— 数据定义[2]SwiftUI 与 Core Data —— 数据获取[3]可以在 此处[4] 获取演示项目...修改为 String )当声明代码可以部分改善在视图中使用托管对象的友善度。相较于将具有默认值的属性声明为可选值类型( 例如 String ),数值属性的声明则更加令人困惑。...事实上,在 Xcode 自带的 Core Data 模版中,就是这样使用的。image-20221212101526366但这确实是正确的使用方式吗?是否会有严重的安全隐患?...另外,在其他的一些操作中,为了保证模态视图的稳定,我们通常也会将模态视图挂载到 List 的外面。例如:@State var item: Item?....now).timeIntervalSince1970)") }}运行上面的代码,在数据被删除后,Sheet 视图中的 item 会因 managedObjectContext 为 nil 而使用备选数据
提供苹果实时榜单查询,包含 iOS 和 iPad 的热门免费榜、热门付费榜、畅销榜,还有新上架榜、新上架免费榜、新上架付费榜等。...2.1 排行榜 首先,App Store 的榜单有很多,包含 iOS 和 iPad 的热门免费榜、热门付费榜、畅销榜,还有新上架榜、新上架免费榜、新上架付费榜等,我们都实现了这些榜单。...就是可以监听 App 在商店的状态,举例来说,App 发布了新版本,那么大概要多久才能在商店上显示呢?所以,我们可以通过苹果的接口,来定时的查询 App 的状态,从而知道 App 什么时候生效。...Top Grossing iPad Applications 最畅销的 iPad 应用 应用分类 分类 ID 英文说明 解析 6000 Business 商务 6001 Weather 天气 6002...- Stack Overflow[15] 另外,就是苹果 API 的坑,接口返回的字段 im:id、im:bundleId,包含冒号,让人怀疑人生!最后,通过自定义键值名,解决了解析映射的问题。
SwiftUI提供了对这些标准手势的内置支持,所以你的大部分应用输入都依赖于它们。当你想超越标准手势,使用ARKit创建自定义手势。...在任何SwiftUI应用中,你都可以使用场景将内容放到屏幕上。场景包含要在屏幕上显示的视图和控件。场景还定义了这些视图和控件出现在屏幕上时的外观。...视图为您的界面提供基本内容,您可以使用SwiftUI修饰符自定义视图的外观和行为。...将指针移动到窗口栏旁边的圆圈上,显示窗口的关闭按钮。将光标移动到窗口的一个角落,以将窗口栏变为调整大小控件。 tips:应用程序不能控制窗口在空间中的位置。...使用visionOS,应用程序自动获得具有visionOS外观和感觉的材料,完全可调整大小的窗口,间距调整为眼睛和手输入,并为您的自定义控件提供高亮显示调整。
肘子的话 苹果用 M4 来展现拥抱 AI 的决心 在 5 月 7 日,苹果终于在时隔一年半后更新了 iPad 系列,其中最引人注目的是,新款 iPad Pro 直接搭载了最新的 M4 芯片。...所有迹象都指向,苹果将在 WWDC 2024 上推出若干与 AI 有关的更新和新功能、新服务。...根据开发者设置的变换规则,对该容器提供的尺寸进行计算后,以此作为视图的建议尺寸。从某种意义上讲,它可以视为一个允许自定义变换规则的特殊版本 frame 修饰器。...迁移结果表明,Tuist 不仅解决了与 CocoaPods 相关的问题,还显著改善了 app 的启动时间和减小了二进制文件的大小。此外,与 CocoaPods 相比,Tuist 的编译时间更短。...文章通过多个模型的转换实例,探索了该工具的效率和效果,包括对较小模型的自定义转换尝试。
想了解更多信息,可以查看我的文章 - SwiftUI 布局系统第三章 目前,我们的按钮是垂直排列的,并且填满了水平线上的可用空间(你可以用以上示例代码预览按钮的样子),虽然这在竖向的 iPhone 上看起来很好...虽然我们也有很多方法能解决这些问题(例如使用类似在这篇 Q&A 中用来使多个视图具有相同宽度和高度的技术),但真正的问题是当我们要动态的确定方向时,测量可用空间是否是一个好的方法。...(例如在大尺寸的 iPhone 使用横屏,或者全屏 iPad 上的任一方向),而其它所有尺寸的配置使用垂直布局。...Xcode 14 的一部分仍在测试阶段) 其中一个工具是新的 Layout 协议,它既能让我们创建完整的自定义布局,直接集成到 SwiftUI 的布局系统中,同时也提供给我们一种更丝滑更动画的方式在各种布局之间动态切换...因为 VStack 可能总是合适的,即使在我们希望布局是横向的情况下(例如 iPad 的全屏模式)。
SwiftUI修饰方法) 以上原则,在SheetKit——SwiftUI模态视图扩展库[3]和用NavigationViewKit增强SwiftUI的导航视图[4]中均有体现。...•只支持部分类型的设备•支持的键盘类型有限 例如在iPad下keyboardType是无效的,在苹果鼓励应用程序对多设备类型支持的今天,让用户在不同的设备上享受到相同的体验至关重要。...如果你需要判断的是日期或其他自定义格式数据,最好也在代码中提供针对本地化字符的处理过程。 Formatter SwiftUI的TextField目前对新老两种Formatter都提供了对应的构造方法。...•可持续性(SwiftUI向后兼容性)方案二由于完全采用SwiftUI方式编写,因此其可持续性从理论上应强于方案一。.../posts/uikitInSwiftUI/ [3] SheetKit——SwiftUI模态视图扩展库: https://www.fatbobman.com/posts/sheetKit/ [4] 用NavigationViewKit
自定义布局Q:我经常想根据列表中最长或最短的文字来布置各种小组件。鉴于动态文本大小在应用程序运行时可能会发生变化,衡量给定字体的文本大小的最佳方法是什么?A:你好!我们新的布局协议支持这个功能。...任何自定义布局的完整实现都比我在这里的帖子中快速勾勒出来的要长,但总体思路是,你可以创建一个布局来查询其子级的理想大小并相应地对它们进行排序。...其中 2 个是自定义形状( 基本上是圆角矩形,只有两个角是圆的 ),其中一个是矩形。编译器抛出一个错误,说它花了太多时间来检查视图的类型。...,但原因并非来自实际的视图内容,而是由于 sheet、toolbar 等修饰器中的代码造成的。...截止 SwiftUI 目前的版本,可以通过以下步骤获取到滑动的距离:自定义 struct, 让它实现 PreferenceKey 协议,其自定义结构体,是需要收集的 gemmetry data (视图坐标信息
那么,SwiftUI解决了哪些痛点?带来哪些好处?代码风格如何?敬请阅读本文。 刚刚结束的苹果WWDC推出了一个对于开发者非常重要的框架:SwiftUI。...SwiftUI是一个非常方便快速的构建UI的框架,与最新Xcode设计工具无缝协作,可为所有苹果设备构建UI。开发者通过SwiftUI,利用Swift语法就能够完成代码和设计的同步。...让Xcode for iPad更上一层楼 开发者对Interface Builder的抱怨不是一天两天了,它大大增加了分解视图块以及从视图控制器(view controller)使用视图的工作量,导致出现体积臃肿的视图控制器...此前,无论什么尺寸屏幕的iPad,总是很难将Interface Builder的大小放到iOS上。而拥有更简单,更快速,更安全的SwiftUI为开发人员实现真正的平台独立性迈出了一大步。...感受一下SwiftUI的代码风格 ? Github一个repo整理了在WWDC 2019发布的SwiftUI布局框架的一些官方示例: SwiftUI Essentials 创建和组合视图: ?
AI 尽管因为信息提前泄漏和长时间的预渲染,许多人在 WWDC 之前已对苹果即将带来的 AI 领域变革有所预知,但在亲眼见到 Keynotes 上的演示后,依然令人振奋和鼓舞。...SwiftUI 初次接触 SwiftUI 今年的新特性时,我并未感到特别兴奋。然而,做了更多的研究后,我意识到此次更新在 SwiftUI 的发展史上将具有十分重要的意义。...例如,集成了 UIKit 的手势系统,引入了功能更丰富的自定义容器,Text 自定义渲染以及提供了精确的滚动控制等。...a sidebar[15] by Donny Wals[16] Present a form sheet in SwiftUI[17] by Natalia Panferova[18] Enhanced...Vittoriosi: https://twitter.com/pasqualevitt [49] WWDC 2024 Sample Code: https://t.ly/WqfE6 [50] 探索 WWDC24 上公布的重大更新
领取专属 10元无门槛券
手把手带您无忧上云