PS:UIScrollView的自动布局依赖于子视图,故在scrollview的子视图不能使用scrollView作为Anchor来限定子视图。
另外,UIScrollView的top,left,right,bottom四个constraints必须设定。
由于ScrollView布局的复杂性,通常会先创建一个最外侧的子视图,包裹ScrollView所有的子视图,这样,子视图,就可以不再考虑外部的布局,只考虑内部的布局就可以了。
下图是常用的布局结构
1、最下面的Constraints使用的是对ScrollView的限定,需要top,right,bottom,left四个方向都限定死,但是不限于使用这些限定。
2、在ScrollView上的Constraints是限定的ContentView,该限定,不会起到大小的固定,可以理解成“留白”或者是contentInset,常见的把所有的contact设置成0即可,否则会出现在放大缩小的时候,图片显示不全。
3、那大小到底是谁限制的呢?大小必须依赖非ScrollView或其子视图限制,可以使用自己的限定,或者是ScrollView的父视图,在这里,可以是跟父视图View等宽或带有比例。

本文详细解析了UIScrollView的布局机制及其对子视图的影响,包括如何正确设定顶部、左侧、右侧和底部约束,以及在ScrollView内部如何避免大小限制并实现动态调整。通过创建一个包裹所有子视图的最外侧子视图,简化了复杂布局的管理,并提供了常见布局结构的实例。

846

被折叠的 条评论
为什么被折叠?



