关于一些细节
- UILabel
[label sizeToFit]; //label的大小自动根据文字适应(仅限于自己手动创建的label)
autoresizing使用前的解释:
UIViewAutoresizing是一个枚举类型,默认是UIViewAutoresizingNone,也就是不做任何处理。
typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {
UIViewAutoresizingNone = 0,
UIViewAutoresizingFlexibleLeftMargin = 1 << 0,
UIViewAutoresizingFlexibleWidth = 1 << 1,
UIViewAutoresizingFlexibleRightMargin = 1 << 2,
UIViewAutoresizingFlexibleTopMargin = 1 << 3,
UIViewAutoresizingFlexibleHeight = 1 << 4,
UIViewAutoresizingFlexibleBottomMargin = 1 << 5
};
各属性解释:
UIViewAutoresizingNone
不会随父视图的改变而改变UIViewAutoresizingFlexibleLeftMargin
自动调整view与父视图左边距,以保证右边距不变UIViewAutoresizingFlexibleWidth
自动调整view的宽度,保证左边距和右边距不变UIViewAutoresizingFlexibleRightMargin
自动调整view与父视图右边距,以保证左边距不变UIViewAutoresizingFlexibleTopMargin
自动调整view与父视图上边距,以保证下边距不变UIViewAutoresizingFlexibleHeight
自动调整view的高度,以保证上边距和下边距不变UIViewAutoresizingFlexibleBottomMargin
自动调整view与父视图的下边距,以保证上边距不变
在这里说明一下,如果是经常使用Storyboard/Xib设置autoresizing,那么转变使用代码设置autoresizing的话,容易出现理解错误问题。比如说UIViewAutoresizingFlexibleTopMargin,也许会被误认为是顶部距离不变,其实是底部距离不变。这个解决办法也很简单,只需要把使用代码和使用Storyboard设置autoresizing,它们是相反的,只需要这样去记就可以了。autoresizing组合使用:
也就是枚举中的值可以使用|隔开,同时拥有多个值的功能,可以针对不同的场景作不同的变化。例如:
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleBottomMargin
意思是:view的宽度按照父视图的宽度比例进行缩放,距离父视图顶部距离不变。
其它的组合类似,我这里就不一一列举了。