通过自动布局在 UIScrollView 中使用顶部布局指南

2024-03-21

I want to use the Top Layout Guide in the UIScrollView through Auto Layout. Without the UIScrollView Auto Layout works well with Top Layout Guide. enter image description here

But when I embed the UIButton in UIScrollView, it doesn't. enter image description here

我知道那是因为UIScrollView与 不在同一层次结构级别Top Layout Guide。但我认为可能有一个好的解决方案来解决这个问题。


你感到困惑是对的。这有点违反直觉,但是顶部和底部布局指南与配置 UIScrollView 无关以便其可滚动内容将位于半透明导航栏下方,这就是您想要实现的效果。

该怎么办

鉴于第二张图片中显示的视图层次结构,这就是您在 iOS8 上需要执行的操作:

  1. 配置视图控制器,以便选中“在顶部栏下延伸边缘”(在代码中,使用edgesForExtendedLayout)。这将确保视图控制器布局其根视图,使其位于导航栏下方。

  2. 配置滚动视图约束,以便滚动视图的顶部边缘与其超级视图的顶部边缘的偏移量为零,not距顶部布局指南的空间为零。这将确保集合视图填充根视图,从而也覆盖导航栏,这是滚动视图的内容能够在导航栏下方滚动所必需的。 (IB 可能会在这个问题上与你争论。请参阅下面的脚注。)

  3. 那么现在如何确保滚动视图知道导航栏在哪里,以便(例如)它不知道always将其内容放置在导航栏下方?答案与布局指南无关。在视图控制器中,选中“调整滚动视图插入”框(或在代码中,automaticallyAdjustsScrollViewInsets)。这将导致视图控制器自动调整滚动视图的contentInset属性,以便滚动视图适当地定位其内容。

这会起作用。

这是怎么回事

那么为什么这是这个答案呢?为什么如此令人困惑?

坦率地说,很容易混淆,因为顶部和底部布局指南作为传达有关半透明覆盖元素的布局信息的元素突出地呈现给我们。然而,它们并不是唯一的“半透明感知”布局机制。它们仅与“普通”子视图的定位直接相关,即与视图控制器的根视图无关,并且与 UIScrollView 中的内容无关。

滚动视图(或 UICollectionView 和 UITableView 之类的子类)中的内容始终以更复杂的方式定位,涉及滚动视图本身,受诸如以下属性的影响contentInset, contentOffset等等(真的,如果滚动视图布局是一件简单的事情,为什么苹果在过去四年里专门举办 WWDC 会议来讨论滚动视图布局?!)

总而言之,如上述步骤所示,three用于管理布局的不同半透明感知机制如下:

  1. 延伸边缘确定视图控制器是否定位其根视图,使其位于导航栏下方。

  2. 布局指南提供一个指标来告诉“主要”内容区域在哪里,并考虑到半透明条。您可以将它们与自动布局一起使用来定位普通视图,这样它们就不会重叠。或者您可以访问代码中的数值。

  3. 滚动视图插图是确保滚动视图的内容可以重叠但并不总是重叠的正确方法。这automaticallyAdjustsScrollViewInsets在简单的情况下,视图控制器上的属性可以自动为您执行此操作。 (大概,这个属性只会导致视图控制器更新滚动视图的contentInset基于它通过布局指南公开的相同值。因此,如果您需要自己管理插图,那么您就可以这样做。)

对抗IB的布局指南狂热

关于“与IB战斗”的脚注:

不幸的是,当您尝试将滚动视图边缘限制到其父视图的边缘时,Interface Builder 可能会与您对抗。如果您从滚动视图按住 Ctrl 键拖动到超级视图,则当它弹出要在这些视图之间添加的可能约束的菜单时,它可能会尝试让您根据视图控制器的布局指南来约束滚动视图。这是因为当超级视图是根视图时,IB 盲目地更喜欢布局指南而不是超级视图边缘。但是当你使用滚动视图时,这是错误的事情.

为什么?例如,假设您接受针对布局指南的约束。然后,您的滚动视图将受到顶部约束,将其限制为 topLayoutGuide-64.0。 -64.0 是一个硬编码值,用于补偿导航栏的确切高度。那么,当天气好的时候导航栏不等于 64pt 时会发生什么情况呢?或者当您完全关闭导航栏时?或者想在没有导航栏的情况下重复使用这个场景?答案:那么你会得到一个损坏的布局。

那么,如何强制 IB 添加从滚动视图到其父视图边缘的约束,而不是布局指南呢?据我所知,答案是您无法通过在视图之间按住 Ctrl 键拖动来在 IB 中正确添加该约束。

相反,您需要选择视图,然后使用画布底部的“固定”控件。这个看起来像一个大写的 H,中间有一个盒子。在“固定”弹出对话框的顶部部分(带有显示超级视图空间限制的小图表的部分),您可以使用文本字段旁边的下拉控件来配置空间限制是否绑定布局指南或超级视图。如下所示:

演示项目的 Github 链接:https://github.com/algal/ScrollViewUnderlapDemo https://github.com/algal/ScrollViewUnderlapDemo

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

通过自动布局在 UIScrollView 中使用顶部布局指南 的相关文章

随机推荐

  • 自定义 WordPress 主题:布局图像不显示

    我正在构建一个自定义 WordPress 主题 所以我的主题文件夹包含以下文件 文件夹 header php index php footer php style css images picture 1 jpg 我的问题是我无法使用正确显
  • 检查特定输入文件是否为空

    在我的表单中 我有 3 个用于文件上传的输入字段
  • iPhone iOS 如何在适当的位置翻转/反射任何 UIView?

    我知道如何通过在其边界内重新绘制 UIImage 来翻转 反射 旋转它 IBAction reflectImageView UIImageView imageView UIGraphicsBeginImageContextWithOptio
  • 配置的 iPhone 未显示在 Xcode Organizer(或 iTunes)中

    我最近设置了应用程序 ID 和配置文件 并且能够在设备上成功测试我的应用程序 然后 我下载了一些示例 iOS XCode 项目 在部署其中一个项目并从手机中删除示例应用程序后 我无法将手机与 iTunes 同步 也无法在 Xcode 管理器
  • iOS 自动续订在当前订阅期结束时过期

    我订购了自动续订产品 5分钟后 它就过期了 我认为在Sandbox中5分钟等于1个月 当前订阅期结束时 5分钟后 不应该自动续订吗 但它已经过期了 在沙盒环境中 自动续订订阅的时间比实际时间要短得多 从这个答案 https stackove
  • 在两个单独的脚本之间共享变量[重复]

    这个问题在这里已经有答案了 我正在尝试在两个单独的选项卡中运行的两个不同的 Tampermonkey 脚本之间共享变量 我尝试在一个脚本中使用 GM setValue 然后在另一个脚本中使用 GM getValue 检索它 但没有成功 所以
  • XML:跨越其他元素的里程碑或元素

    我正在与OSIS http bibletechnologies net 开放圣经信息标准 用于描述圣经和相关文本的 XML 模式 当我第一次查看 XML 示例时 我注意到一些以前在 XML 中从未见过的奇怪之处 主要是关闭的标签 然后是逻辑
  • ANDROID_HOME 和 ANDROID_SDK_ROOT 环境变量均未导出 - Windows 10

    我是一个初学者 正在学习appium工具 尝试启动 appium 会话并收到错误 An unknown server side error occurred while processing the command Original err
  • 如何使用 mysqli 插入 MySQL

    我刚刚学习数据库 我希望能够存储用户输入 关于如何使用 PHP 获取表单数据并将其保存到数据库的基本示例是什么 还确保表单安全SQL攻击 http en wikipedia org wiki SQL injection File 示例 ht
  • Scala脚本等待mongo完成任务

    我正在编写一个简单的基于 scala 的脚本 该脚本应该将一些数据插入 Mongo 集合中 问题是 该脚本在 mongo 完成其任务之前退出 考虑以下脚本 处理该问题的惯用 最佳方法是什么 usr bin env scalas scalaV
  • 如何检查可以找到多少列字符[重复]

    这个问题在这里已经有答案了 我有一个包含 4 列的数据集 其中包含名称 其中名称的数量和名称的顺序在列之间有所不同 某些列还可以包含相同的名称两次或更多次 看起来如下 df lt data frame x1 c Ben Alex Tim L
  • SQL Server 将字符串长度减少到 8000 个字符

    我正在尝试将数据插入列数据类型为的表中NTEXT 理想情况下 它应该存储超过 8000 个字符 但在我的情况下 它会将其减少到 8000 个字符 我正在程序中运行时进行插入查询 以下是该过程正在进行的示例查询 INSERT INTO TMP
  • Eclipse 中的 CPLEX 库路径错误

    我正在使用 eclipse 进行 java 编码 我完成了代码 它在 CPLEX 库 12 6 上运行良好 我在属性 gt 库 gt 添加外部 jar gt cplex jar 中添加了库 我想更改CPLEX 12 7的库 所以我删除了以前
  • POI条形图生成一系列有问题

    我使用 JDK8 和 POI 4 1 0 使用它们的示例herea link http svn apache org repos asf poi trunk src examples src org apache poi xwpf user
  • c 中 tan(90) 的值?

    它给出的值是 557135813 94455 每次值都会保持不变吗 为什么它不显示无穷大 include
  • DISTINCT() 和 ORDERBY 问题

    我正在学习 LINQ to SQL 一切都很顺利 直到发生了一些奇怪的事情 我试着举个例子distinct 因此 使用 Northwind 数据库 我编写了以下查询 var query from o in db Orders orderby
  • 带有徽标的 A 框链接

    我想使用徽标从场景内部链接到外部 URL 常规网站 而不是 VR 这就是我所拥有的
  • 使用新安装的模块而无需重新启动交互式会话

    在长时间的交互会话 使用 ipython 中 我有时需要使用尚未安装的模块 安装新模块后 该模块可以在新的交互式会话中导入 但不能在安装之前运行的会话中导入 由于我正在使用内存中的所有变量 我不想重新启动会话 我怎样才能获得这样一个先前运行
  • 你能推荐一些Python HTTP客户端库吗? [关闭]

    Closed 这个问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 我想使用Python从一些网站捕获信息 我希望HTTP客户端满足这个条件 支持HTTPS 不会使用太多
  • 通过自动布局在 UIScrollView 中使用顶部布局指南

    I want to use the Top Layout Guide in the UIScrollView through Auto Layout Without the UIScrollView Auto Layout works we