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

掌握 SwiftUI 的 Safe Area

掌握 SwiftUI 的 Safe Area 访问我的博客 www.fatbobman.com[1] 可以获得更好的阅读体验 Safe Area(安全区域)是指不与导航栏、标签栏、工具栏其他视图控制器提供的视图重叠的内容空间...在 UIKit 中,开发者需要利用 safeAreaInsets safeAreaLayoutGuide ,才能确保将视图放置在界面中的可见部分。 SwiftUI 对上述过程进行了彻底的简化。...除非开发者明确要求视图突破安全区域的限制,否则 SwfitUI 将尽力确保开发者创建的视图都被布局到安全区域当中。SwiftUI 同时提供了一些方法和工具让开发者对安全区域有所控制。...本文将探讨如何在 SwiftUI 中获取 SafeAreaInsets、将视图绘制到安全区域之外、修改视图的安全区域等内容。...在 SwiftUI 中,开发者通常只有在需要获取 StatusBar + NavBar 的高度 HomeIndeicator + TabBar 的高度时才会使用到 safeAreaInsets 。

7.5K31

SheetKit——SwiftUI模态视图扩展库

SheetKit——SwiftUI模态视图扩展库 新写了个的SwiftUI Sheet扩展库,添加对可变高度Sheet的支持。...•模态视图的集中管理SwiftUI通常采用.sheet来创建模态视图,对于简单的应用来说,这种形式非常直观,但如果应用程序的逻辑比较复杂、需要的模态视图众多,则上述方式就会让代码显得十分混乱,不易整理。...因此,在此种情况下,通常我们会将所有的模态视图集中管理起来,统一调用。请参阅我之前的文章——在SwiftUI中,根据需求弹出不同的Sheet[3]。...使用下面语句将关闭显示动画 SheetKit().present(animated: false) Sheet类型 目前SheetKit支持三种模态视图类型:sheet、fullScreenCover、...[2] SheetKit: https://github.com/fatbobman/SheetKit [3] 在SwiftUI中,根据需求弹出不同的Sheet: https://www.fatbobman.com

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

iOS13 Scene Delegate

在上面的代码中,我们可以手动地设置了视图控制器堆栈,稍后会进行详细介绍。...application(_:didDiscardSceneSessions:) : 在分屏中关闭其中一个多个scene时候回调用,可以在该函数中销毁场景所使用的资源。...didDiscardSceneSessions sceneSessions: Set) { } } 3)第三步,SceneDelegate中初始化UIWindow,并添加根视图控制器...接着为SwiftUI项目创建了ContentView实例,并通过使用UIHostingController将其添加为根视图控制器。 该控制器用于将基于SwiftUI视图显示在屏幕上。...scene(_: willConnectTo: options: )函数内,创建一个SwiftUI视图,将其放置在托管控制器中,然后将控制器分配给window属性的根视图控制器,并将该窗口放置在应用程序

5.1K20

如何在SwiftUI中实现interactiveDismissDisabled

Sheet•在用户使用手势取消Sheet时可以获得通知,进而拥有更多的控制能力 最终实现的效果如下: dismissSheet 当用户有未保存的数据时,通过手势取消Sheet将被阻止,用户需明确选择保存丢弃数据...默认情况下,展示(present)Sheet的视图控制器(UIViewController)是没有设置委托的。因此,只要将定义好的委托实例在视图中注入给特定的视图控制器即可实现以上需求。...那么A的presentationController就是我们需要注入delegate的视图控制器。...delegate = delegate } }} makeUIView中只需要创建一个空视图(UIView),由于在执行makeUIView时,无法保证Sheet中的视图已经被正常展示...next } return nil }} 如此,便可以通过下面的代码为展示Sheet的视图控制器注入delegate了 uiView.parentViewController

3.8K40

SwiftUI案例:自定义加载动画

SwiftUI案例:自定义加载动画 效果 目标 使用图片实现自定义加载动画 点击加载弹出层外部任意一点可关闭动画演示 开关可控制图片采用“垂直移动动画”“垂直加自身旋转动画” 外观配置 视图的实现...ContentView.swift 案例通过在间隔时间内不断控制变量 animateBall:Bool 与 animateRotation:Bool 的值来间接地实现动画效果; import SwiftUI...showPopUp组成的flag标签组 @State var rotateBall = false //是否旋转图片 @State var showPopUp = false //是否显示弹出层...@Environment(\.colorScheme) var scheme //使用预处理颜色组 var body: some View { //创建纵向布局视图...("图片是否旋转") } .padding() .padding(.horizontal, 10) //弹出演示按钮

1.9K10

SwiftUI-开发iOS项目

UISceneConfiguration实例 完成启动后,控制权被交接给 SceneDelegate,它的 scene(_:willConnectTo:options:)将会被调用,设置window的根视图控制器...在初始化根视图控制器时会初始化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:Alert弹窗

如果发生重要事件,通知用户的一种常见方法是使用警报Alert弹窗-根据您的需要,该弹出窗口包含标题,消息和一个两个按钮。 但是请考虑一下:何时应该显示警报以及如何显示Alert?...视图是我们程序状态的函数,Alert也不例外。因此,我们不用说“显示警报”,而是创建警报并设置显示警报的条件。...基本的SwiftUIAlert具有标题,消息和一个关闭按钮,如下所示: Alert(title: Text("Hello SwiftUI!")...SwiftUI将观察showingAlert,并在它变为true时立即显示警报。...仔细看看alert()修饰符: .alert(isPresented: $showingAlert) 这是另一种双向数据绑定,这是因为SwiftUI会在警报解除后自动将showingAlert设置为false

5.3K20

苹果全新UI框架来了!可视化编程,自动化减少20%代码量

那么,SwiftUI解决了哪些痛点?带来哪些好处?代码风格如何?敬请阅读本文。 刚刚结束的苹果WWDC推出了一个对于开发者非常重要的框架:SwiftUI。...让Xcode for iPad更上一层楼 开发者对Interface Builder的抱怨不是一天两天了,它大大增加了分解视图块以及从视图控制器(view controller)使用视图的工作量,导致出现体积臃肿的视图控制器...感受一下SwiftUI的代码风格 ? Github一个repo整理了在WWDC 2019发布的SwiftUI布局框架的一些官方示例: SwiftUI Essentials 创建和组合视图: ?...动画视图和过渡 ? App Design and Layout 复杂界面组合: ? 使用 UIControls: ? Framework Integration 使用 UIKit: ?...比如,它只支持Swift,你不能在Obj-C里使用SwiftUISwiftUI目前还不是很成熟,正在从事iOS开发的程序员可能更应该继续使用Obj-C,直到SwiftUI足够成熟。

5.3K20

SwiftUI 状态管理系统指南

前言 SwiftUI与苹果之前的UI框架的区别不仅仅在于如何定义视图和其他UI组件,还在于如何在整个使用它的应用程序中管理视图层级的状态。...SwiftUI没有使用委托、数据源任何其他在UIKit和AppKit等命令式框架中常见的状态管理模式,而是配备了一些属性包装器[1],使我们能够准确地声明我们的数据如何被我们的视图观察、渲染和改变。...值得庆幸的是,SwiftUI还提供了一些机制,使我们能够将外部模型对象连接到我们的各种视图。...现在,我们可以用许多不同的方式来描述这样一个对象,但由于我们正在寻找创建一个类型来控制我们的一个模型的实例——让我们把它变成一个符合SwiftUI的ObservableObject协议的模型控制器[2]...尽管在一个父视图和它的一个子视图之间创建绑定通常很容易,但在整个视图层次结构中传递某个对象值可能相当麻烦——而这正是环境变量旨在解决的问题类型。 有两种主要的方法来使用SwiftUI的环境。

5K20

SwiftUI中使用UIKit视图

SwiftUI中使用UIKit视图 如想获得更好的阅读体验可以访问我的博客www.fatbobman.com,点击下方的阅读原文 已迈入第三个年头的SwiftUI相较诞生初始已经提供了更多的原生功能...在相当长的时间中开发者仍需在SwiftUI中依赖UIKit(AppKit)代码。好在,SwiftUI为开发者提供了便捷的方式将UIKit(AppKit)视图控制器)包装成SwiftUI视图。...在UIKit(AppKit)中,视图视图控制器)有明确的生命周期节点,比如vidwDidload、loadView、viewWillAppear、didAddSubView、didMoveToSuperview...•同SwiftUI框架保持沟通上文中,我们提到UIViewRepresentable作为原始类型,需要主动承担更多的同SwiftUI框架其他视图之间的沟通工作。...在协调器中,我们可以通过双向绑定(Binding),通知中心(notificationCenter)其他例如Redux模式的单项数据流等方式,将UIKit视图内部的状态报告给SwiftUI框架其他需要的模块

8.1K20

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

VIPER架构模式是MVCMVVM的另一种选择。虽然SwiftUI和Combine框架创建了一个强大的组合,可以快速构建复杂的ui和在应用程序中移动数据,但它们也面临着各自的挑战和对架构的看法。...控制器Controller修改视图,接受用户输入并直接与模型交互。控制器Controller因视图逻辑和业务逻辑而膨胀。...最大的区别是,视图模型View Model与视图控制器不同,它只有对视图和模型的单向引用。MVVM非常适合SwiftUI。 VIPER更进一步,将视图逻辑与数据模型逻辑分离。...router处理从一个屏幕到另一个屏幕的转换,设置下一个视图所需的类。 在命令式UI范例中——换句话说,在UIKit中——路由router将负责显示视图控制器激活segue。...SwiftUI将所有目标视图声明为当前视图的一部分,并根据视图状态显示它们。

17.3K10

SwiftUI 的动画机制

阅读本文前,读者最好已拥有在 SwiftUI 中使用动画编程的经历,SwiftUI 动画的基本使用方法有一定的了解。可以在 此处获取本文的全部代码[2] SwiftUI 的动画是什么?...关联的方式有:视图修饰符 animation 全局函数 withAnimation 。 SwiftUI 的动画异常(与开发者的预期不符)很多情况下均与错误的关联方式、错误关联位置等因素有关。...当状态的改变导致视图树的分支发生变化时,SwiftUI 将使用其包裹的可动画部件对视图进行动画处理。 使用转场同样需要满足 SwiftUI 动画的三要素。...相较于控件动画,控制器的动画问题则更加难以解决。...除了动画逻辑可以更 SwiftUI 化外,最好也能将 AnyTransition 用于控制器的过渡设定。 动画性能问题 响应式动画的反应略逊于命令式动画几乎是必然的。

14.6K40

解析 SwiftUI 中两处由状态更新滞后引发的严重 Bug

而通过调用环境值直接修改绑定状态,SwiftUI 则遵循了响应式编程原则,进行了的先调整状态,后更新视图的操作。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛聊天室里看到不少的开发者都在寻找解决方法。...它的复现条件非常简单:在真机上测试( 模拟器上不容易复现 )点击 “GO” 按钮进入下一层视图点击 “Show Sheet” 按钮弹出 Sheet通过下滑手势取消 Sheet在 Sheet 取消后(动画结束时...它的复现条件如下:iOS 16 系统,在真机模拟器上测试点击视图列表中的按钮,可以进入下一级视图。...希望 SwiftUI 开发组能尽早重视这些问题。欢迎你通过 Twitter、 Discord 频道 博客的留言板与我进行交流。订阅下方的 邮件列表,可以及时获得每周最新文章。

583110

Airbnb 的三阶段 SwiftUI 迁移实践

如上所述,第一步是基于一系列风格使用 SwiftUI 重建现有的设计系统,这些风格可以通过修饰符实例化并传给视图。这为开发人员使用几行代码轻松定制 UI 组件提供了基础。...第二步是构建基础设施,实现基于 UIKit 的 Epoxy 视图SwiftUI 视图之间的双向桥接。桥接的实现细节可以在原文中找到。...简单地说,桥接是基于 UIHostingViewController(将 SwiftUI 层次结构嵌入到视图控制器)和 UIViewRepresentable(将 UIKit 视图集成到 SwiftUI...为此,他们为每个定义的视图变体起了一个名字,以便与他们的快照测试服务一起使用,并让所有视图变体遵循 Xcode 的 PreviewProvider 协议,以便使用 Xcode 预览。...ViewInspector 允许在运行时遍历视图层次结构,并可直接访问底层“视图”结构体,从而使内部状态变得可检查,并可以编程的方式模拟用户交互。

19410

SwiftUI Overlay Container 2 —— 可定制、高效、便捷的视图管理器

SwiftUI Overlay Container[1] 是一个用于 SwiftUI视图容器组件。一个可定制、高效、便捷的视图管理器。...设计动机 当我们需要在视图的上层显示新的内容(例如:弹出信息、侧边菜单、帮助提示等)时,有很多优秀的第三方解决方案可以帮助我们分别实现,但没有一个方案可以同时应对不同的场景需求。...功能与特性 支持多个容器 单一容器内支持多个视图 可在 SwiftUI 视图代码内视图代码外向任意指定的容器推送视图 可以动态修改容器的配置(除了队列类型) 容器内的视图有多种排列方式 有多种队列类型以指导容器如何显示视图...{ get } } alignment 设置视图视图组在容器中的 alignment。...stacking 模式下,可以为每个视图设置不同的 alignment,在 vertical horizontal 模式下,所有视图视图组)共用容器的 alignment 设置。

2.1K20

SwiftUI 视图的生命周期研究

、viewWillLayoutSubviews 等),开发者可以将自己的意志注入视图控制器生命周期的各个节点之中,宛如神明。...什么是视图 开发者更习惯将符合 View 协议的结构体结构体实例视作视图,而在 SwiftUI 的角度,视图值树上的节点内容,才是它所认为的视图。...通常情况下,SwiftUI 在需要渲染屏幕某个区域需要该区域的数据配合布局时,会在视图值树上创建对应的视图。当不再需要其参与布局渲染时视图将被销毁。...比如在 List 和 LazyVStack 中,Cell 视图在创建之后即使滚动出屏幕不参与布局与渲染,但 SwiftUI 仍会保留这些视图的数据,直到 List LazyVStack 被销毁。...因此,我认为应该以视图是否参与影响了其父视图的布局作为 onAppear 和 onDisappear 的触发条件。如果用此条件来解释上面的情况便完全可以说的通了。

4.3K30

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

是否有任何建议用来检测列表中的行选择,类似于 “NavigationLink”,但不导航到另一个视图(例如,显示 Sheet 从列表中选择一个选项 )?...如果你不想让父视图也被更新,可以在创建对象时不使用 @StateObject @ObservedObject 。...A:当在其他类型的 UIViewControllers 中使用 UIHostingController 时,你可能会通过调用托管控制器的方法来触发视图加载提前发生。...对于惰性视图,当在 hosting controller 视图上调用 layoutSubviews sizeThatFits 方法时,会初始化视图。...在有些情况下,我想根据视图是否折叠来做决定( 例如,如果展开,在详细视图中显示一条信息,如果折叠,则显示一个警告其他指示 )。

12.2K20

解析 SwiftUI 中两处由状态更新滞后引发的严重 Bug

而通过调用环境值直接修改绑定状态,SwiftUI 则遵循了响应式编程原则,进行了的先调整状态,后更新视图的操作。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死 这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛聊天室里看到不少的开发者都在寻找解决方法。...它的复现条件非常简单: 在真机上测试( 模拟器上不容易复现 ) 点击 “GO” 按钮进入下一层视图 点击 “Show Sheet” 按钮弹出 Sheet 通过下滑手势取消 Sheet 在 Sheet 取消后...它的复现条件如下: iOS 16 系统,在真机模拟器上测试 点击视图列表中的按钮,可以进入下一级视图。...由于在返回上层视图时,状态尚未更新,因此在清理 AG 时(返回动画运行中),会破坏应用程序的 AttributeGraph 完整性,从而导致应用程序死锁崩溃。

26220

从用SwiftUI搭建项目说起

PreviewProvider协议的结构体里面的,就像下面我们要说的基本的Tab的预览: struct BaseTabbarView_Previews: PreviewProvider { /// 预览视图...在UIKit中我们的导航、标签都是通过控制器来管理,但是在SwiftUI中他们分别是通过NavigationView+TabView管理的,我们得在认识上有一个基本的转变,从Controller到View...简单看看Na+Tb的代码 ---- 从SceneDelegate开始, 根控制器就是 UIHostingController,我们需要做的第一步就是设置它的根视图 rootView //...当 @State 装饰过的属性发生了变化,SwiftUI 会根据新的属性值重新创建视图 */ @State private var selectedTab = 0 var...字体的颜色 }.accentColor(.blue) } } struct BaseTabbarView_Previews: PreviewProvider { /// 预览视图

4.4K20

AVKit框架详细解析(四) —— 基于AVKit 和 AVFoundation框架的视频流App的构建

将播放器视为能够一次管理一个媒体资产的播放的控制器对象。 3) VideoPlayer 是一个方便的 SwiftUI 视图,需要播放器对象才能发挥作用。 您可以使用它来播放视频。...4) 默认情况下,SwiftUI 视图考虑设备的安全区域。 由于呈现超出状态栏和主页指示器的视频播放器看起来更好,因此您添加了此修饰符。...构建并运行,然后滚动到feed的底部以找到 キツネ村(kitsune-mura) Fox Village 视频。 这就是 VideoPlayer 的美妙之处; 您只需要一个 URL,就可以开始了!...AVPlayerLayer } 为了能够在 SwiftUI 中使用此视图,您需要使用 UIViewRepresentable 创建一个包装器。...缺点是,在撰写本文时,iOS 14.5是可用的最新版本,VideoPlayer 的 SwiftUI 视图未显示画中画按钮。

6.9K10
领券