OGeek|极客世界-中国程序员成长平台

标题: ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题? [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-11 19:37
标题: ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题?

Implement Edit and Delete Behavior 结束时在官方 iOS 应用程序开发教程部分,提到布局有错误,使用堆栈 View 修复这些错误留给读者练习。 为了修复它们,我遵循了以下步骤:

  1. 添加一个水平堆栈 View ,其中将包含 UIImageView 和一个垂直堆栈 View 。
  2. 将水平堆栈 View 的边缘约束到父 View 的边缘。
  3. 将标签和评级控制添加到垂直堆栈 View 。
  4. 在 UIImageView 中将内容模式设置为 Aspect Fit。
  5. 将 UIImageView 的 CHCR 属性设置为全 1000。

Your Meals Scene

但是,布局仍然不是我喜欢的。例如,我在 iPhone 5 模拟器中启动了应用程序,情况如下:

Your Meals Scene on iPhone 5

ImageView 不会扩展到单元格顶部和底部(保持纵横比)。此外,当我点击“编辑”时, ImageView 会缩小而不是评级控制和标签:

enter image description here

类似地,当我们向左滑动一行时,不是将 label 和 Rating Control 缩小,而是将 ImageView 滑出 View :

enter image description here

我希望 ImageView 完全保留在那里,并根据需要缩小评级控制和标签。

我还尝试将 Rating Control 替换为包含 5 个普通按钮的普通水平堆栈 View 。结果如下:

enter image description here

enter image description here

enter image description here

enter image description here

这一次,UIImageView 覆盖了整个单元格。我已经预料到了:

  1. UIImageView 的高度等于单元格的高度。
  2. UIImageView 的宽度与高度成正比(因为我在 Interface Builder 中将 UIImageView 的 Content Mode 设置为 Aspect Fit)。
  3. 标签和新评级控制要覆盖的剩余空间。他们应该占用剩余空间,因为我已将 UIImageView 的 CHCR 设置为全部 1000。

更新:

这是在 ImageView 中添加纵横比约束后的 View :

enter image description here

enter image description here

几乎完成了,除了 ImageView 不是从左边缘开始的事实。为了解决这个问题,我尝试将 ImageView 的前沿位置设置为 super View 的前沿位置,但这没有帮助。

我怎样才能达到想要的布局?



Best Answer-推荐答案


滑动删除部分的工作完全正常。整个单元格向左滑动而不是向左收缩(看看 Mail.app,你会发现它的行为方式相同)。

至于另一个问题,当表格处于编辑模式时, ImageView 是唯一缩小的部分……

  1. 调低评级 View 和标签的抗压性。
  2. 为 ImageView 添加纵横比约束。
  3. 选择 ImageView 和内容 View (使用 您截取屏幕截图的大纲 View 中的命令键)并设置 他们有相同的高度。 这应该可以防止 ImageView 在编辑模式下缩小。如果不尝试在单元格顶层的水平堆栈 View 的各种模式。

关于ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43819187/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://ogeek.cn/) Powered by Discuz! X3.4