在 Implement Edit and Delete Behavior 结束时在官方 iOS 应用程序开发教程部分,提到布局有错误,使用堆栈 View 修复这些错误留给读者练习。
为了修复它们,我遵循了以下步骤:
- 添加一个水平堆栈 View ,其中将包含 UIImageView 和一个垂直堆栈 View 。
- 将水平堆栈 View 的边缘约束到父 View 的边缘。
- 将标签和评级控制添加到垂直堆栈 View 。
- 在 UIImageView 中将内容模式设置为 Aspect Fit。
- 将 UIImageView 的 CHCR 属性设置为全 1000。
但是,布局仍然不是我喜欢的。例如,我在 iPhone 5 模拟器中启动了应用程序,情况如下:
ImageView 不会扩展到单元格顶部和底部(保持纵横比)。此外,当我点击“编辑”时, ImageView 会缩小而不是评级控制和标签:
类似地,当我们向左滑动一行时,不是将 label 和 Rating Control 缩小,而是将 ImageView 滑出 View :
我希望 ImageView 完全保留在那里,并根据需要缩小评级控制和标签。
我还尝试将 Rating Control 替换为包含 5 个普通按钮的普通水平堆栈 View 。结果如下:
这一次,UIImageView 覆盖了整个单元格。我已经预料到了:
- UIImageView 的高度等于单元格的高度。
- UIImageView 的宽度与高度成正比(因为我在 Interface Builder 中将 UIImageView 的 Content Mode 设置为 Aspect Fit)。
- 标签和新评级控制要覆盖的剩余空间。他们应该占用剩余空间,因为我已将 UIImageView 的 CHCR 设置为全部 1000。
更新:
这是在 ImageView 中添加纵横比约束后的 View :
几乎完成了,除了 ImageView 不是从左边缘开始的事实。为了解决这个问题,我尝试将 ImageView 的前沿位置设置为 super View 的前沿位置,但这没有帮助。
我怎样才能达到想要的布局?
Best Answer-推荐答案 strong>
滑动删除部分的工作完全正常。整个单元格向左滑动而不是向左收缩(看看 Mail.app,你会发现它的行为方式相同)。
至于另一个问题,当表格处于编辑模式时, ImageView 是唯一缩小的部分……
- 调低评级 View 和标签的抗压性。
- 为 ImageView 添加纵横比约束。
- 选择 ImageView 和内容 View (使用
您截取屏幕截图的大纲 View 中的命令键)并设置
他们有相同的高度。
这应该可以防止 ImageView 在编辑模式下缩小。如果不尝试在单元格顶层的水平堆栈 View 的各种模式。
关于ios - 如何修复官方 iOS 应用开发教程中的 Auto Layout 问题?,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/43819187/
|