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

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

前言在应用显示应用图标和版本是为用户提供快速识别应用版本和变体的好方法,无论是内部用户(测试人员或利益相关者)还是外部用户。...在本文中,我将展示如何创建一个可访问的 SwiftUI 视图,既能显示应用图标和版本,又能在各种文本大小和外观下看起来都很好:获取应用图标构建视图的第一步是主包获取应用图标。...可以通过检索应用的 Info.plist 文件的一组键值来完成, Stack Overflow 上的这个答案所示:AppIconProvider.swiftimport Foundationenum...我们在一个水平堆栈显示应用图标和版本,间距为12点。我们在 Image 视图中显示应用图标。...我们学习了如何在 SwiftUI 应用显示应用图标和版本信息。

15922

SwiftUI 状态管理系统指南

前言 SwiftUI与苹果之前的UI框架的区别不仅仅在于如何定义视图和其他UI组件,还在于如何在整个使用它的应用程序管理视图层级的状态。...SwiftUI没有使用委托、数据源或任何其他在UIKit和AppKit等命令式框架中常见的状态管理模式,而是配备了一些属性包装器[1],使我们能够准确地声明我们的数据如何被我们的视图观察、渲染和改变。...属性状态 由于SwiftUI主要是一个UI框架(尽管它也开始获得用于定义更高层次结构(应用程序和场景)的API),其声明式设计不一定需要影响应用程序的整个模型和数据层——而只是直接绑定到我们各种视图的状态...一种是首先在想要检索给定对象的视图中定义一个EnvironmentObject包装的属性——例如像这个ArticleView如何检索一个包含颜色信息的Theme对象: struct ArticleView...小结 SwiftUI管理状态的方式绝对是该框架最有趣的方面之一,它可能需要我们稍微重新思考数据在应用的传递方式——至少在涉及到将被我们的UI直接消费和修改的数据时是这样。

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

    在 iOS 16 中用 SwiftUI Charts 创建一个折线图

    系列文章 如何在 SwiftUI 创建条形图 SwiftUI 的水平条形图 在 iOS16 中用 SwiftUI 图表定制一个线图 在 Swift 图表中使用 Foudation 库的测量类型 简单折线图...包含一周的步数的数据开始,类似于 在SwiftUI创建折线图 中使用的数据。...这些可以通过将图表标记LineMark改为其他类型的标记(BarMark)来生成条形图。...创建第二个系列,即前一周的步数,并将这两个系列添加到折线图中。...Charts 创建一个包含两个系列步数数据的折线图 第一次尝试在 SwiftUI Charts 创建一个包含两个系列步数数据的折线图 显示步数系列 在折线图中显示多个基于工作日的步数系列 最初尝试在折线图中显示多组数据的问题是

    3.7K20

    何在SwiftUI实现interactiveDismissDisabled

    何在SwiftUI实现interactiveDismissDisabled 想获得更好的阅读体验,可以访问我的博客www.fatbobman.com[1] 本文中我们将探讨如何实现一个SwiftUI...3.0新增功能——interactiveDismissDisabled的增强版;如何创建更SwiftUI化的功能扩展。...需求 由于健康笔记[2]数据录入都是在Sheet中进行的,为了防止用户在录入过程由于误操作(使用手势取消Sheet)丢失数据,因此,最初的版本开始,我就一直使用各种手段加强对Sheet的控制。...在WWDC 2021 观后感[6]一文,我们已经探讨过SwiftUI3.0将会影响非常多的第三方开发者编写SwiftUI扩展的思路和实现方式。...因此,只要将定义好的委托实例在视图中注入给特定的视图控制器即可实现以上需求。

    3.9K40

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

    在单元测试,很难对 SwiftUI图中的依赖( 符合 DynamicProperty 协议 )进行测试。这也是 Redux-like 框架的优势之一( 将状态图中抽离出来,方便测试 )。...我试着在 ToolbarItemGroup(place: .bottomBar) 添加一个 TextFiled ,在 ToolbarItemGroup(place: .keyboard) 添加第二个...在我的例子,不拖动时 0 到 75,拖动时 0 到 100。有什么办法可以阻止这种情况吗?A:你可以用 .chartYScale(domain: 0 ... 75) 锁定 Y 轴的刻度域。...阅读 SwiftUI 的动画机制[8] 一文,了解更多有关动画的内容。自适应高度 SheetQ:如何在 iOS16 呈现与动态内容高度相匹配的 Sheet?...image-20221022135326560San Francisco 宽度风格Q:如何在 SwiftUI 如何使用 SF 字体家族新增的三种宽度风格( Compressed、Condensed、Expanded

    12.2K20

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

    该方法的 Persistent History 部分有助于确保你不会大量重复地数据获取数据,并且仅在你需要的数据发生更改时才刷新。又是一个有关持久化历史跟踪的问题。...当前,应用程序调用 API 是索引删除项目的唯一方法。当前 Spotlight 确实无法处理类似的状况。...检索 NSAttributedStringQ:我需要将 NSAttributedString 存储在数据,并且可以对属性字符串的任何文本进行搜索。...生成对应数据的纯文本以进行检索,是一种很常见的方式。在某些情况下,即使属性的原始内容为纯文本,也可以通过为其生成标准化版本( 忽略大小写以及变音符号的版本 )以提高检索效率。...数据手动排序Q:在我的应用程序,用户可以在表视图中通过拖放来重新排列项目。

    3.2K20

    在iOS 16SwiftUI Charts创建一个折线图

    在iOS 16SwiftUI Charts创建一个折线图 苹果在WWWDC 2022上推出了SwiftUI图表,这使得在SwiftUI图中创建图表变得异常简单。...在SwiftUI创建折线图 How to create a Bar Chart in SwiftUI 简单折线图 包含一周的步数的数据开始,类似于在SwiftUI创建折线图中使用的数据。...这些可以通过将图表标记LineMark改为其他类型的标记(BarMark)来生成条形图。...创建第二个系列,即前一周的步数,并将这两个系列添加到折线图中。...Charts 创建一个包含两个系列步数数据的折线图 在折线图中显示多个基于工作日的步数系列 最初尝试在折线图中显示多组数据的问题是X轴使用了日期。

    3.4K20

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

    Swiftcord[12] 的代码展示了如何在 SwiftUI 下实现倒置列表。阅读 优化在 SwiftUI List 显示大数据集的响应效率[13] 一文,了解苹果工程师推荐的方法。...在两种方案,如果在数据量很大的情况下,我更倾向于第一种方式,这样可以按需求读取数据。...macOS APIQ:对于运行 Monterey 的 Mac,能否如何在 SwiftUI 实现下面需求的建议:打开一个窗口在该窗口中初始化数据找到所有打开的窗口确定一个窗口是否打开从不在该窗口的视图中关闭一个窗口...对于可能造成卡顿的图片数据,放弃托管对象的图片关系中直接获取的方式。在 Cell 视图中,通过创建 request 私有上下文中提取数据并转换成图片。...在 SwiftUI ,有一个第一版开始就存在但尚未公开的纯 SwiftUI 实现的滚动容器 —— _ScrollView 。

    14.8K30

    何在Xcode下预览含有Core Data元素的SwiftUI视图

    何在Xcode下预览含有Core Data元素的SwiftUI视图 SwiftUI诞生之日起,预览(Canvas Preview )一直是个让开发者又爱又恨的功能。...结合两年来我在SwiftUI中使用Core Data的经验和教训,我们将在本文中探讨: •导致SwiftUI预览崩溃的部分原因•如何在之后的开发避免类似的崩溃出现•如何在Xcode安全可靠地预览含有...虽然它完全破坏了单向数据流的逻辑和美感,但由于它过分的好用,因此在SwiftUI的开发仍被广泛的采用。...为SwiftUI预览提供Core Data数据 本节,我们将介绍几种为预览组织Core Data数据的方式,提高SwiftUI+Core Data的开发效率。...SwiftUI通常采用Redux的开发模式,通过将获取到的Core Data数据转换成标准的Swift结构从而避免在视图中使用托管对象上下文或托管对象。

    5.1K10

    SwiftUI 与 Core Data —— 数据定义

    遗憾的是,托管对象对于以值类型为主的 SwiftUI 来说并不算友好,因此,不少开发者都会在视图中将托管对象实例转换成一个结构体实例以方便接下来的操作( 如何在 Xcode 下预览含有 Core Data...我们可以根据需要随时调整 TodoGroup ,而无需过分考虑如何在 Core Data 以及数据组织数据( 仍需要开发者有一定的 Core Data 编程基础,避免创建完全不切实际的数据格式 )。...对于 SwiftUI 来说,托管对象具备两个非常显著的特点:懒加载托管对象的所谓托管是指:该对象被托管上下文所创建并持有。仅在需要的时候,才数据库( 或行缓存 )中加载所需的数据。...这个类型除了用于为 SwiftUI 的视图提供数据外,同时也会被用于为其他的数据流提供有效信息,例如,在类 Redux 框架,通过 Action 为 Reducer 提供所需数据。...我们将介绍如何在视图 Core Data 获取数据的操作这一过程实现与托管环境解耦,创建一个可以接受 Mock 数据的自定义 FetchRequest 类型。

    2.4K40

    SwiftUI:使用 @EnvironmentObject 环境读取自定义值

    但是我们也可以将自定义对象发送到环境,并在以后将它们读出来,这使我们可以在复杂的应用程序更轻松地共享数据。...使用@EnvironmentObject,视图A可以将对象放入环境,视图E可以环境读取对象,而视图B,C和D不必知道发生了什么。...首先,这是我们可以使用的一些基本数据: class User: ObservableObject { @Published var name = "Taylor Swift" } 您所见,使用...当然,我们可以在单个视图中表示出来,但是通过这种方式,您可以确切地看到使用环境对象时通信的无缝性。 现在,这是最聪明的部分。...现在,您可能想知道SwiftUI何在.environmentObject(user)和@EnvironmentObject var user: User之间建立连接——如何知道将该对象放入正确的属性?

    9.6K20

    SwiftUI TextField进阶——格式与校验

    何在TextField实现格式化显示 现有格式化方法 在SwiftUI 3.0,TextField新增了使用新老两种Formatter的构造方法。...开发可以直接使用非String类型的数据整数、浮点数、日期等),通过Formatter来格式化录入的内容。...如何在TextField屏蔽无效字符 现有屏蔽字符方法 在SwiftUI,可以通过设置仅使用特定的键盘类型来实现一定程度上的录入限制。...如何在TextField检查内容是否符合指定条件 相较上述两个目标,在SwiftUI检查TextField内容是否符合指定条件是相当方便的。...不利于判断用户是否录入新的信息(更多的信息可参阅如何在SwiftUI创建一个实时响应的Form[10])。方案二允许不提供初始值,支持可选值。

    8.1K20

    SwiftUI 掌握 ScrollView 的使用:滚动可见性

    要了解有关 scrollTargetLayout 视图修饰符的更多信息,请查看我的文章《掌握 SwiftUI 的 ScrollView:滚动几何》。...pause() } } }}在上述示例,我们定义了阈值,这意味着 SwiftUI 将在视图至少有 10% 可见时运行操作闭包。...同样,当视图可见状态转换为不可见状态,即显示的口部分少于 10% 时,也会运行该闭包。...每个数字都显示在一个 Text 视图中,并有不同的背景颜色。...此外,在页面底部有一个视频播放器,当视频播放器出现在口内时,它会自动播放,当其离开口时,会自动暂停。总结今天,我们学习了如何跟踪 ScrollView 内特定视图的可见性,并监控可见标识符列表。

    15110

    SwiftUI 实战使用 MapKit API

    前言SwiftUI 与 MapKit 的集成在今年发生了重大变化。在之前的 SwiftUI 版本,我们将 MKMapView 的基本功能封装到名为 Map 的 SwiftUI图中。...幸运的是,事情发生了变化,SwiftUI 引入了与 MapKit 集成的新 API。本篇文章我们将学习如何在 SwiftUI 的最新版本中使用可用的新功能丰富的 API 与 MapKit 集成。...正如我之前所说,在 SwiftUI 框架的早期版本,我们有一个 Map 视图,为我们提供了 MapKit 的基本功能,该功能现在已被弃用。...让我们使用 SwiftUI 中最新迭代中提供的新 MapKit API 集成的基本示例开始。...MapInteractionModes 类型定义了一组交互,平移、俯仰、旋转和缩放。默认情况下,它启用所有可用的交互类型。总结今天,我们学习了在 SwiftUI 中集成 MapKit 的基础知识。

    13200

    SwiftUI 新容器视图 API 深度解析:轻松构建自定义布局

    通过在 Card 容器视图内嵌入不同的视图,你可以在应用的多个屏幕复用它。这是使用容器视图的主要优势之一:你可以通过将共享的功能封装在容器视图中,在应用的不同地方重复使用它们。...使用 ViewBuilder@ViewBuilder 闭包让我们可以轻松地组合多个视图,并将一个视图嵌入到另一个视图中。但是如何 @ViewBuilder 闭包中提取子视图呢?...SwiftUI 引入了新的 API,允许我们重新组合视图。例如,我们可以通过 @ViewBuilder 闭包构建的内容视图中提取子视图,并根据需要将它们放置。...我们还利用了 id 参数的功能,允许我们使用 ForEach 视图与普通数据一起工作。...运行这个Demo此代码展示了如何在 SwiftUI 构建自定义的容器视图,灵活地将不同的布局封装在容器,以便在应用多次复用这些布局模式。

    11410
    领券