自动布局之autoresizingMask

简述

IOS的两大自动布局方式:autoresizing 和 autolayout(autolayout是IOS6以后新增)。autoresizing是UIView的属性,一直存在,使用也比较简单,但是没有autolayout那样强大。如果你的界面比较简单,要求的细节没有那么高,那么你完全可以使用autoresizing去进行自动布局。

UIViewAutoresizing

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 or Xib设置autoresizing,那么转变使用代码设置autoresizing的话,容易出现理解错误问题。比如说UIViewAutoresizingFlexibleTopMargin,也许会被误认为是顶部距离不变,其实是底部距离不变。这个解决办法也很简单,只需要记住使用代码和使用Storyboard设置autoresizing是相反的就可以了。

autoresizing组合使用:

也就是枚举中的值可以使用”|”隔开,同时拥有多个值的功能,可以针对不同的场景作不同的变化。例如:

//view的宽度按照父视图的宽度比例进行缩放,距离父视图顶部距离不变。
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleBottomMargin
注意:view的autoresizesSubviews属性为yes时(默认为yes),autoresizing才会生效。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值