自动布局—— UIViewAutoresizing(autoresizingMask) (IOS开发)

本文介绍了iOS开发中的自动布局利器UIViewAutoresizing,它是一个枚举类型,用于简单的自动布局。通过设置不同的枚举值,可以实现视图随父视图尺寸变化时的不同响应。例如,可以设置视图的宽度、高度、边距等如何自动调整,以适应界面布局需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

2.  UIViewAutoresizing是一个枚举类型,默认是UIViewAutoresizingNone,也就是不做任何处理。

typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {

    UIViewAutoresizingNone                 = 0,                      //不会随父视图的改变而改变

    UIViewAutoresizingFlexibleLeftMargin   = 1 << 0,    //自动调整view与父视图左边距,以保证右边距不变 

    UIViewAutoresizingFlexibleWidth        = 1 << 1,          //自动调整view的宽度,保证左边距和右边距不变

    UIViewAutoresizingFlexibleRightMargin  = 1 << 2,     //自动调整view与父视图右边距,以保证左边距不变

    UIViewAutoresizingFlexibleTopMargin    = 1 << 3,      //自动调整view与父视图上边距,以保证下边距不变

    UIViewAutoresizingFlexibleHeight       = 1 << 4,         //自动调整view的高度,以保证上边距和下边距不变

    UIViewAutoresizingFlexibleBottomMargin = 1 << 5    //自动调整view与父视图的下边距,以保证上边距不变

};

 

3.  autoresizing组合使用

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

3.1// 设置文字控件的宽度按照上一级视图(topView)的比例进行缩放

label.autoresizingMask = UIViewAutoresizingFlexibleWidth;

3.2// 设置View控件的宽度按照父视图的比例进行缩放,距离父视图顶部、左边距和右边距的距离不变

view.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleLeftMargin;

3.3// 设置View控件与父视图的左边距和右边距的比例不变,上边距和下边距的比例不变(实质图片保持了原来的大小)。

view.autoresizingMask = UIViewAutoresizingFlexibleBottomMargin | UIViewAutoresizingFlexibleLeftMargin | UIViewAutoresizingFlexibleRightMargin | UIViewAutoresizingFlexibleTopMargin;

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值