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

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

因此,如果你正在创建一个视图来显示可滚动的内容,并可能进行选择操作,那么在 iOS 和 macOS 上使用 List 将有最好的体验。...创建从底部开始的滚动视图Q:我如何实现一个在底部对齐的滚动视图,在 macOS 上会不会有糟糕的性能?...A:你最好的选择是使用 ScrollView 和 ScrollViewReader,并在 onAppear 或新内容进来时滚动到最底部的视图。我不建议尝试旋转滚动视图。...将背景扩展到安全区域Q:如果我有一个自定义的容器类型,可以接受一个顶部和底部的视图,是否有办法让 API 的调用者将所提供的视图的背景扩展到安全区域内,同时将内容( 如文本或按钮 )保留在安全区域内?...然而,两个内容相同的视图之间的交换并不能使视图顺利地产生动画,因为两者的文本也被动画化了。我正在使用仅禁用 TextField 的替代方法,但有没有办法引导动画以使用文档中的方法?

14.8K30

Vcl控件详解_c++控件

:可获得封装列表视图中所有项目的矩形屏幕坐标允许应用程序调整组件的大小,允许适应项目成确定鼠标是否在其列表项目上 Checkboxes:在项目前是否加入一个CheckBox Column:只读,...对指定的列进行操作 ColumnClick:可指定当用户标题时是否将发生OnColumnClick事件 Columns:对列进行操作 DropTarget:可列表视图中项目是否以拖放操作的目标显示...:可在列表视图有焦点时获得用户输入的字符序列,列表视图添加字符串到查找字符串,并查找匹配的项 IsEditing:判断当前用户是否正在对项目进行操作 Scroll:可通过水平像素和垂直像素滚动列表视图的内容...该事件只有在OwnerData属性为True时有效 OnDeletion:当列表视图中的一个项目被删除时触发 OnDrawItem:当绘制一个项目时触发 OnEdited:当编辑一个项目的Caption...OnInfoTip:当用户停止在列表视图中的一个项目上时触发 OnInsert:在列表视图中插入一新的项目发生 OnSelectItem:当选中项目时触发 THeaderControl

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

    使用相交观察器和SQIP进行渐进式图像加载

    延迟加载图像背后的想法是,你需要等到用户进一步向下滚动页面,并在发出网络请求之前将图像放入视图中。...如果你的网页包含多个图像,但你只能在滚动查看图像时加载每个图像,则最终会节省带宽,并确保网页加载速度更快 这让我思考;我想知道是否可以将交叉观察者和使用Tobias的SQIP工具创建的低质量占位符图像结合起来...使用延迟加载技术将意味着用户只加载他们在视口中看到的内容,而与低质量图像相结合则意味着双重网页性能会带来麻烦 在这篇文章中,我将通过我所经历的步骤和您如何开始使用这种技术来谈谈您自己 开始入门 在我们继续之前...,然后再确定它是否在视图中。...使用IntersectionObserver的默认选项,当元素部分进入视图并完全离开视口时,你的回调将被调用。在这种情况下,我正在通过一些额外的配置选项到IntersectionObserver。

    1.8K20

    最新iOS设计规范四|3大界面要素:视图(Views)

    “取消”按钮应出现在动作表单的底部。 突出显示破坏性选择。将红色用于执行破坏性或危险操作的按钮,并将这些按钮显示在动作表单的顶部。 避免让操作表滚动。如果表单选项太多,用户必须滚动才能看到所有选项。...屏幕上需要阅读的文字应该越少越好,可以尝试编写一个标题并且避免添加额外的信息。因为单字标题很少会提供有用的信息,所以可以考虑以问问题或使用短句的方式,尽可能的将标题保留在同一行上。...不要在一个滚动视图中放置另一个滚动视图。这样做带来的后果主要为会产生一个不可预期的用户界面,从而控制起来会变得非常困难。 同一时刻只显示一个滚动视图。...相反,将内容添加到表的开头或结尾,让用户在准备好时滚动到它。一些APP在加载新数据时会显示一个加载器,并提供一个直接跳转到该数据的控件。最好还包括一个刷新控件,这样用户就可以随时手动进行更新。...避免将索引与包含右对齐元素的表单结合在一起。索引一般通过大的滑动手势来控制的。如果附近存在其他交互元素,例如显示指示器,则在出现手势时很难辨别用户的意图,并且可能会激活错误的元素。

    8.5K31

    用这些 iOS 技巧让你的 APP 性能更佳

    text = "Cell \(indexPath.row)" return cell } 你可能已经想到,当你滚动到底部时,这将为设备的内存添加一千个 tableViewCell。...将启动页用作启动画面以显示品牌或添加加载动画是一个常见的错误。如 Apple 所述,应将启动页设计为与应用的第一个页面相同: 「设计一个与应用程序首页几乎相同的启动页。...当你新建 iOS 项目时,Xcode 会创建一个空白的 LaunchScreen.storyboard 供你使用。当应用程序加载视图控制器和布局时,将向用户显示此页面。...译者注:文段中没有 Xcode,下文中提及为 Xcode 新建项目 为了让你的应用感觉更快,你可以将启动页设计为与将向用户显示的第一个页面(视图控制器)类似。...我们需要做的就是添加一些配置来告诉应用程序支持状态保存和恢复,以及告诉应用程序需要保存哪些数据。

    3.2K30

    【Hybrid开发高级系列】ReactNative(七) —— RN组件专题

    这些都显示为图标或小部件右侧的文本。如果不适合,它们将 被放置在一个'溢出'菜单。         ...        列表视图——为变化的数据列表的垂直滚动的高效显示而设计的一个核心组件。...如果重新呈现它们耗费很大,那就把它们包在StaticContainer或其他适当的机制中。在每一个呈现过程中,页脚始终是在列表的底部,页眉始终在列表的顶 部。...默认值应该是没问题的,但是如果你每一 个按键都操作的非常缓慢,那么你可能想尝试增加这个。     ...4.1.2 将静态资源添加到您的Android应用程序中         将您的图像作为位图画板添加到android项目中( /android/app/src/main/res)。

    58340

    最新iOS设计规范五|3大界面要素:控件(Controls)

    虽然你可以在任何类型的视图中使用它们,但详情展开按钮通常是用于列表中,便于用户访问有关某行列表的信息。 ? 在列表中适当使用详情展开按钮。...添加联系人按钮 用户可以点击“添加联系人”按钮来浏览现有联系人列表,并选择一个要插入到文本字段或其他视图中的联系人。...七、选择器(Pickers) 选择器可以显示一个或多个可滚动的不同值列表,供人们选择。在iOS 14及更高版本中,日期选择器支持其他选择值的方式,例如在日历视图中选择日期或使用数字键盘输入日期和时间。...选项为中长列表时,可以考虑使用选择器。如果需要显示太短的选项列表,请考虑使用下拉菜单而不是选择器。尽管选择器使您可以轻松快速地滚动浏览许多项目,但它可能会给一小部分项目增加太多视觉效果。...刷新控件是活动加载指示器的一种特殊类型,默认情况下处于隐藏状态,并在向下拖动要重新加载的视图时可见。例如,在“邮件”中,您可以将“收件箱”邮件列表向下拖动以检查是否有新邮件。 ? 执行自动内容更新。

    8.6K30

    unity3d新手入门必备教程

    在工程视图(Project View)中可以查看资源文件夹。如果你打开过资源文件夹,你将发现所有的项都将出现在工程视图中。不同的是在工程视图中,你将创建并将物体连接在一起。...当从场景中添加或删除一个物体时,它将在层次中显示或消失。如果你不能在场景视图中同时看到所有物体,你可以使用层次来选择并检视它们。    ...时间线视图将帮助你为物体制作动画    参考动画部分    调整视图布局现在你已经知道了所有不同的视图,你可以重新布局它们    布局下拉列表然你选择或保存不同视图布局    尝试选择不同的布局...第一种方式是单击添加打开场景 (Add Open Scene)按钮,你将看到当前的场景出现在列表中。第二种方法就是从工程视图 (Project View)中将场景文件拖动到列表中。    ...然而有一些改动将断开它,下面是保持预设连接的基本规则:    ?不能添加一个新的组件到一个实例上    ?不能从一个实例上移除一个组件    ?

    6.4K10

    iOS 9人机界面指南(四):UI元素(下)- 腾讯ISUX

    设计一个与应用的风格协调的活动指示器。可以的话,让活动指示器的尺寸和颜色与它所在的背景协调。 4.3.2 添加联系人按钮 添加联系人按钮让用户将现有联系人添加到文本框或者其它文字视图中。 ?...添加联系人按钮: 展示联系人列表 帮助用户将一个联系人添加到当前联系人按钮所在的视图中 使用添加联系人按钮让用户在不需要使用键盘的情况下就可以方便地访问到联系人。...一般来说,你会在一个表格视图中使用详情展开按钮来让用户知道更多关于这个列表项的信息。当然你也可以将这个按钮用在其它类型的视图中来为用户展示更多与特定项目相关的信息和功能。...但请注意,由于键盘的布局以及输入方法是由用户的系统语言设置决定的,这是你不能控制的。 4.4临时视图 4.4.1 警告框 警告框用于告知用户一些会影响到他们使用app或设备的重要信息。 ?...如果你必须为警告框添加正文文本,请使用一个完整的短句。可能的话,尽量保证句子在1到2行之间。如果句子太长,用户会需要滚动才能看完,这样的体验很糟。使用句子式大写,并在句末加上适当的标点符号。 ?

    13.2K30

    clientWidth,offsetWidth,scrollWidth你分的清吗

    ---- 前言 最近在开发时遇到这样一个需求,一个表单列表报错后,滚动表单到能展示报错元素,做的时候发现clientWidth,offsetWidth,scrollWidth这几个概念自己有时候还是会弄混...;  var Y = node.getBoundingClientRect().top+node.scrollTop; 一个demo加深印象 有一个列表,当我们输入文段编号,列表会将选中文段滚动到视图中...大概是这样 实现思路就是,去拿到选中元素的clientHeight和offsetTop,并和列表的高度区间做比较,计算出元素是在列表视口的内部,还是溢出的视口,如果溢出了视口,那么就回滚。...top; // 选中元素距离浏览器的高度 const { top } = this.pRef[`ref${value}`].getBoundingClientRect(); // needScroll就是元素底部距离滚动容器顶部的距离...|| needScroll < 0) { // 将选中元素放入容器视口中 const timer = setTimeout(() => { this.scrollRef.scrollTop

    2.1K10

    从零开始的Android:常见的UI设计模式

    大家好,又见面了,我是你们的朋友全栈君。 尽管Android允许您创建几乎任何可能需要的自定义视图或用户界面,但事实证明,在正确的情况下,有一些用户界面模式可以很好地适用于用户。...尽管此模式称为列表和详细信息,但没有理由也不能将相同的逻辑应用于网格设计。 此模式的关键特征是,列表/网格中的每个项目在被选中时都应执行显示更多详细信息的相同操作。...在此模式中,您将采用列表和详细信息模式,并在同一屏幕上多次使用它。 区别在于列表项可以水平滚动而不是垂直滚动。...当您的应用程序中只有几个部分时,此模式很有用,因为它为用户提供了一种快速简便的方法来更改视图。 但是,如果要在选项卡中放入五个或更多项目,则应考虑将导航操作移到抽屉中。...根据Android的材料设计指南,选项卡也可以存在于屏幕底部,如Google+应用程序所示。 导航抽屉 导航抽屉是一个视图,可以从应用程序的侧面滑出,以便向用户显示选项列表。

    2.7K20

    微信小程序实践:2.3 可滚动的容器组件之 scroll-view

    像scroll-top、scroll-left这两个属性,它们是通过属性绑定、控制组件行为的属性。如果我们想让滚动实体滚动到某个位置,并不能直接调用它的一个类似于scrollTo()的方法。...也就是说,纵向滚动,使scroll-top等于子视图的上边界;横向滚动,使scroll-left等于子视图的左边界。 这是一个语法糖属性,它帮助开发者做了一些事情。...但这种操作有一个问题。setData受限于视图层与逻辑层之间用于传话的evaluateJavascript函数,其每次携带的数据大小,官方评测标准要求在文本序列化以后大小不能超过256KB。...我在vue项目中曾实现过一个类似的长列表组件,以前推过文章,可以在这里查看:15 v-if 条件渲染与 v-for 列表渲染。...问题是解决了,但牺牲了一些性能。如果内容少,建议直接添加一个看不见的容器,使内容高度一定大于滚动框架的高度,就没有这个问题了。

    15.3K30

    iOS 9人机界面指南(四):UI元素(上) - 腾讯ISUX

    如果需要在工具栏上展示3个以上的项目,可以使用图标。由于文本按钮通常会比图标更占空间,所以用图标可以避免文字标题们挤在一起。 保证工具栏文字按钮之间有足够的间距。...有时候用户会觉得以列表呈现的信息更容易阅读和理解,例如将文本信息放在滚动列表中的时候,用户阅读和处理起来会更为简单和高效。 让视图中的项更容易选中。...使用滚动条效果的时候,当前页面将滚动到下一页;而使用翻页效果时,页面上会出现一个模拟实体书或笔记本翻页效果的翻页动画 使用页面视图控制器来展示那些线性的内容(比如一个故事的文本),或者是一些可以被自然地拆分成块的内容...浮出层的高度是不固定的,因此你可以用它来承载一个很长的项目列表。但一般来说,还是应当避免需要滚动浮出层才能开启一个任务。请注意,系统可能会调整浮出层的宽高,以让它能够更好地适应屏幕的尺寸。...当用户在视图中拖拽内容,内容随之滚动;当用户轻扫屏幕时,内容将快速滚动——直到用户再次触摸屏幕或内容已经到达底部时停止。

    10.1K51

    WebRender:让网页渲染如丝顺滑

    前一部分基本上是在构建计划:渲染器将 HTML 和 CSS 以及视口大小等信息结合起来,确定每个元素应该长成什么样(宽度,高度,颜色等)。...合成器(compositor)从这两部分开始: 源位图:背景(包括可滚动内容所占的空白框)和可滚动内容本身 目标位图:屏幕所显示的位图 首先,合成器将背景复制到目标位图中。...从列表中删除任何不必要的形状(早期剔除) 节省时间的最好办法是什么都不做。 首先,RenderBackend 可以减少显示列表项目。它会识别哪些项目将真正出现在屏幕上。...例如边框着色器,文本着色器,图像着色器。 ? 我们认为可以将很多着色器结合起来,这样就能够增加批处理容量。但目前这样已经相当不错了。 已经可以准备将它们发送给 GPU 了。...我们正在尝试通过 Pathfinder 项目将字形等工作转移到 GPU 上。 这些内容目前是被 CPU 绘制成位图的。然后把它们上传到 GPU 的纹理缓存中。

    3K30

    最新iOS设计规范三|3大界面要素:栏(Bars)

    在拆分视图中,导航栏可能会显示在拆分视图的单个窗格中。导航栏是半透明的,也可以添加背景色,并且必要时可以设置为隐藏。 ? 某些情况下可暂时隐藏导航栏,以提供更沉浸的体验。...导航栏标题 在导航栏中显示当前视图的标题。在多数情况下,标题可以帮助人们了解他们在看什么。但是如果添加导航栏显得多余,则可以将标题留为空白。...六、工具栏(Tool Bars) 工具栏出现在页面的底部,其中包含执行与当前视图或内容相关操作的按钮。工具栏是半透明的,也可以添加背景颜色,并在用户不需要它们时应该隐藏起来。...例如:在Safari中,当你开始滚动页面时,工具栏会自动隐藏,因为你可能正在阅读。你还可以点击屏幕底部让它再次出现。当弹出键盘时,工具栏也会被隐藏。 ?...工具栏包含用于执行与当前上下文有关的动作的按钮,例如创建项目,删除项目,添加注释或拍照。标签栏和工具栏永远不会在同一视图中同时出现。 提供相应的工具栏按钮。

    9.9K10

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

    是否有任何建议用来检测列表中的行选择,类似于 “NavigationLink”,但不导航到另一个视图(例如,显示 Sheet 或从列表中选择一个选项 )?...只有将这些变量重构到视图模型中去这一种方式?A:如果在同一个视图中,有多个相互关联的 @State 属性,将他们提取到一个结构中或许是好的选择。...假设我们想创建一个类似于 iMessage 的视图,在那里你可以看到一个信息列表(与本例无关),在视图的底部有一个文本框。当用户点击文本字段时,键盘会在其工具栏中出现一个文本字段。...给我一些方向来完成它吗?A:一般来说,我建议使用 .safeAreaInset(edge: .bottom) 来实现底部文本字段。然后根据它的焦点状态来定制它的显示样式。希望这对你的设计有用。...我已经开始采用 NavigationSplitView,并且非常喜欢它。在有些情况下,我想根据视图是否折叠来做决定( 例如,如果展开,在详细视图中显示一条信息,如果折叠,则显示一个警告或其他指示 )。

    12.3K20

    独家 | 手把手教数据可视化工具Tableau

    Tableau概念 为何有一些字段维度和其他度量?添加筛选器将对我的视图产生什么影响?为何一些字段的背景颜色是蓝色,而另外一些字段的背景颜色是绿色?...在将这些值添加到视图中时,状态栏的右侧将显示一个精度警告。 5....Tableau 窗口底部的状态栏显示视图中现在有三个标记: 这些标记只包含占位符文本 Abc,因为您此时只构建了视图的结构。 STEP 2: 将“Region”(区域)拖到“列”。...通过将“Sales”(销售额)拖到到“文本”来调整这一点。现在可以认为视图是完整的: 说明: 1. 某些情况下,向视图中添加度量可能会增加视图中标记的数量。...该度量将聚合为一个总和并将创建一个轴,列标题将移到视图的底部。 由于您添加了日期维度,因此 Tableau 会使用“线”作为标记类型。 STEP 4: 在“标记”卡上,从视图下拉列表中选择“条形”。

    18.9K71

    SceneKit 场景编辑器-为您的AR体验构建3D舞台

    您可以将文件夹命名为您想要的任何名称,但这是它在Xcode的ARKit模板中的标签,它是一个非常好的标准。名称本身就是解释性的。如果展开文件夹,请注意此处存储了飞船场景。...移动它们以直观地重新定位模型。它们之间的弧度是一次用一个轴旋转对象。 视口控件 视口下方是视口控件。在这个栏上,我们可以改变到不同的视角。我经常将它设置为前面,因为这是在屏幕上添加模型时的起始角度。...场景图视图 打开场景时,通常会隐藏场景图视图。要显示它,请单击视口下方左下方的小窗口图标,在控件旁边。在这里,您可以看到组成场景的所有部分。这些对象是几何,灯光,相机等节点。...我们先添加一些形状。为此,请转到对象库,该对象库是视口右上角的图标。如果您有Xcode 9,它位于右侧面板的底部。您将看到可添加的对象列表。黄色物体是灯光,而绿色物体是几何形状。...暂停阅读并尝试添加它然后自己定位。 如果您猜对了,它就是一个管子,因为管子中间是空心的。因此,请从对象库中添加它。 管子尺寸 管子有2个半径,一个内部和一个外部。

    5.6K20
    领券