1.在ViewController中拖入1个UIScrollView,并为其添加约束
约束为上下左右四边与superview对齐
data:image/s3,"s3://crabby-images/70e6f/70e6f23f4420bfbe7245ddc935d73769dc4e4b5e" alt=""
2.在scrollview中,拖入1个UIView,为了便于区分将其设为橙色。
data:image/s3,"s3://crabby-images/8e306/8e3068b0b38065cd5dc8f7b88c3b35b9aed3d390" alt=""
3.为view添加约束
约束为上下左右四边与superview对齐(在这里与scrollview对齐)
data:image/s3,"s3://crabby-images/fb55f/fb55f3e00993949232b61d7a8b75f4e7b43b6b5f" alt=""
添加完这些约束后,我们发现出现了错误,不要理会
data:image/s3,"s3://crabby-images/bb17c/bb17c15c472ab620cf24c97768b5c623b79df3db" alt=""
4.为view添加宽度约束,本例中,想达到的效果是scrollView可以竖向滚动,不要横向滚动,
因此,可以将view的宽度约束为与scrollView相同
data:image/s3,"s3://crabby-images/cae7a/cae7a69161fce8c65761e956cff96db70dceaee2" alt=""
5.接下来为view添加高度约束
data:image/s3,"s3://crabby-images/56829/56829c601889fe87422fec57b3937d01fce289d3" alt=""
对frame进行更新
data:image/s3,"s3://crabby-images/b4681/b4681a22314816357ca1dc93f288c4e3a6772339" alt=""
愉快的发现约束错误已经消失!
为了验证scrollView是否可以正确滑动
我们在scrollView中添加一个兰色的view,添加宽高约束分别为60,500,然后再添加到黄色view(也就是兰色view的superview)的左边距和上边距
data:image/s3,"s3://crabby-images/a28b7/a28b71509a27a8f967ac5aa923764aa8b1d22a6c" alt=""
至此,约束全部添加完成。需要滚动的内容都可以在黄色view中添加。
点击运行查看效果
data:image/s3,"s3://crabby-images/3957a/3957aa44bc1b3ab61de67043c5c4f159f11b0c61" alt=""
可以看到scrollview可以按照预期滑动
最后,全部的约束见下图
data:image/s3,"s3://crabby-images/2c723/2c723b172ef7dd8b9fb2035378f4d07be4d5eaae" alt=""
UIScrollView添加约束要点:
1.scrollView与scrollView的superview的约束关系用来确定scrollView的frame
2.scrollView中的『contentView』(本例中的兰色view)的约束关系用来确定scrollView的contentInsets
3.contentView的宽度和高度用来确定scrollView的contentSize
理解这3个要点,即可愉快的为scrollView添加约束
(来源:cnblogs.com作者:ashamp)
网友评论