swift – UIScrollView导致“错位视图”AutoLayout问题

swift – UIScrollView导致“错位视图”AutoLayout问题,第1张

概述当我使用UIScrollView时,我遇到了一个奇怪的AutoLayout相关问题(没有它就不会发生这个问题). 我有一个UIScrollView受限于UIView的边界(包含在UIViewController中),在其中,我试图并排放置UILabel和UITextField.我已将UILabel约束到左边界和上边界,并限制了它的宽度和高度(见下面的截图): 这个UILabel旁边是一个UITex 当我使用UIScrollVIEw时,我遇到了一个奇怪的autoLayout相关问题(没有它就不会发生这个问题).

我有一个UIScrollVIEw受限于UIVIEw的边界(包含在UIVIEwController中),在其中,我试图并排放置UILabel和UITextFIEld.我已将UILabel约束到左边界和上边界,并限制了它的宽度和高度(见下面的截图):

这个UILabel旁边是一个UITextFIEld,它被限制在左侧,顶部和右侧,并且高度受限.但是,这会导致错位视图”警告,指出“预期宽度= 163,实际宽度= 413”,如下面的屏幕截图所示:

当我选择“重置为建议的约束”时,“错位视图”问题消失了,但在它的位置我留下了413点的宽度约束,这是我希望避免的,因为我不喜欢这个UIVIEwController可在较小的设备上水平滚动.

解决方法 滚动视图具有大小(屏幕上占用的大小)和内容大小(整个可滚动区域的大小).在“自动布局”中,将根据滚动视图中项目的约束自动计算内容大小.这是一个问题,因为您尝试使滚动视图与屏幕具有相同的宽度,然后将项目限制为该范围.执行此 *** 作时,“自动布局”会强制您为文本字段指定显式宽度,以便计算可滚动区域的宽度.

要做你想做的事,请执行以下 *** 作:

>在滚动视图中添加“内容视图”.此视图将是滚动视图中唯一的顶级项目.它会将您的所有内容保存为子视图.拖出UIVIEw并将其添加到滚动视图中.将其顶部,前导,底部和尾部边缘限制在滚动视图中.将其宽度限制为滚动视图的宽度.给它一个高度约束并设置它你想要你的内容区域.>将所有标签和文本字段添加到此内容视图中.现在,您可以将它们限制在内容视图的中心或约束到边缘,它将按您的需要工作.

总结

以上是内存溢出为你收集整理的swift – UIScrollView导致“错位视图”AutoLayout问题全部内容,希望文章能够帮你解决swift – UIScrollView导致“错位视图”AutoLayout问题所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1009586.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存