Autolayout在UIScrollView中的使用(一)

由于UIScrollView是个容器View,熟悉UIScrollView的人都知道设置scrollview一般都要设置其frame、contentSize两个属性。


在Autolayout使用中,遇到UIScrollView是最头疼的一件事。废话不多说,直接上问题:


问题1


用xib或storyboard时,经常会出现,如果你想让放在UIScrollView里面的View跟着UIScrollView的拉伸而拉伸,而不是固定高度或宽度,结果你就用了上、下、左、右约束。


靠,满满的全是错误!!!!


不对啊,我都设置了UIScrollView跟父View的边距约束了,放里面的View再跟UISrollView的边距加约束,理论上是对的啊?


看看错误,提示错误为 “ScrollView Has ambiguous scrollable content height / width”,注意是crollable content height / width。


看了官方文档后才知道,如果在UIScrollView里面添加View,UISrollView是要通过给View添加约束来确定contentSize的。好吧!


解决方法:


1、给View加高宽约束,但这样就不能随UIScrollView拉伸了。

2、给View添加Alignment约束,如果是水平拉伸,就设置水平alignment。这样拉伸妥妥的。问题解决 !!!!


实际开发中,上下都拉伸的适配,完全背离苹果推出大屏的目的,人家好不容易把屏幕做大,想给用户展示更多的内容,你丫的一下垂直、水平都拉大了!感觉一下变成了老人机。


扯淡到此结束!哈哈。


我在适配6、6+时,多遵从这个博客的理念http://daily.zhihu.com/story/4252195?utm_campaign=in_app_share&utm_medium=iOS&utm_source=sina



问题2

适配时,有时需要宽度拉伸,高度不变,于是我就照着上面的方法添加约束,在5s上跑没问题(注意,我是用的4寸的xib模型)。但跑到3.5寸,问题又来了




为什么,3.5寸可滚动区域怎么这么长,下面还有这么长的空白,在4寸上看还行,但到了3.5寸上看着就是不爽,像我这样的偏执狂,就是不能容忍!靠。。。。


看看哪个地方造成的??


看了以后,原来这样


我给View加了距离下面380约束,但我不加,就会报和上面一样的错误!要是设置小了,会不会报错呢?


想想应该不会,View的约束间接确定的是contentSize大小!对,我设置

20看看,OK!


但问题又来了,contentSize小于frame.size时,就不能滚动了!抓狂。。。。。看API,惊奇的发现 alwaysBounceVertical 属性,让其始终可以滚动,(心里不禁暗骂,当初谁告诉我:contentSize小于frame.size时,就不能滚动了)。哈哈,搞定!!!



下面用autolayout适配,遇到UIScrollView得心应手。


写了这么多(我是用来做我的笔记的)。我对 Autolayout + UIScrollView 的总结就是:


1、UIScrollView里面放View时,切记,View是要确定UIScrollView的contentSize,有时候限高、限宽是很有必要的。如果你发现里面的View不能确定UIScrollView的contentSize,那必然会出错。


2、别把UIScrollView里面最下面的View距离下边框设置的太高,设个20-30就可以了(如果有人就喜欢设置高点,可以,但体验肯定不好),UIScrollView照样可以滚。



更多内容读者可以自行参照苹果官方文档:

https://developer.apple.com/library/ios/documentation/UserExperience/Conceptual/AutolayoutPG/AutoLayoutbyExample/AutoLayoutbyExample.html#//apple_ref/doc/uid/TP40010853-CH5-SW1

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值