iOS8 UIView之autoresizingMask 的使用

  • UIView的autoresizingMask属性 是用来适应父视图的变化(根据父视图的变化进而调整自身Frame属性)。
@property(nonatomic) BOOL autoresizesSubviews; // default is YES. if set, subviews are adjusted according to their autoresizingMask if self.bounds changes
@property(nonatomic) UIViewAutoresizing autoresizingMask;    // simple resize. default is UIViewAutoresizingNone

UIView 的属性autoresizesSubviews 默认设置是YES,如果设置为YES,当视图的bounds变化的时候,子视图将根据自身的autoresizingMask属性调节Frame属性。

  • autoresizingMask有以下属性(默认值为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
};
  • 例子
 1 #import "TestViewController.h"
 2 @interface TestViewController()
 3 @property (nonatomic,weak) UIView * superView;
 4 @end
 5
 6 @implementation TestViewController
 7 -(void)loadView
 8 {
 9     [super loadView];
10     UIView * superView = [[UIView alloc] initWithFrame:CGRectMake(20, 20, 100, 200)];
11     superView.backgroundColor = [UIColor redColor];
12     [self.view addSubview:superView];
13     self.view.backgroundColor = [UIColor whiteColor];
14     _superView = superView;
15     UIView * subView = [[UIView alloc] initWithFrame:CGRectMake(0, 20, 50, 40)];
16     superView.autoresizesSubviews = YES;
17
18 //  1、设置subView随superView的bounds变化,上、下、左、右边距和宽高都随superView的变化而变化
19     subView.autoresizingMask = UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleHeight | UIViewAutoresizingFlexibleBottomMargin|UIViewAutoresizingFlexibleLeftMargin|UIViewAutoresizingFlexibleRightMargin|UIViewAutoresizingFlexibleWidth;
20 //  2、设置subView随superView的bounds变化,上、下、高都随superView的变化而变化,而左右边距和宽度不变
21     subView.autoresizingMask = UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleHeight | UIViewAutoresizingFlexibleBottomMargin;
22 //  3、设置subView随superView的bounds变化,上边距和高都随superView的变化而变化,而下、左、右边距和宽度不变
23     subView.autoresizingMask = UIViewAutoresizingFlexibleTopMargin | UIViewAutoresizingFlexibleHeight;
24 //  4、单一属性一般不做此类设置(没看出到底什么效果)
25 //    subView.autoresizingMask = UIViewAutoresizingFlexibleTopMargin;
26 //  5、设置subView随superView的bounds变化,下边距和高都随superView的变化而变化,而上、左、右边距和宽度不变
27     subView.autoresizingMask = UIViewAutoresizingFlexibleHeight|UIViewAutoresizingFlexibleBottomMargin;
28 //  6、设置subView随superView的bounds变化,左边距和宽都随superView的变化而变化,而上、下、右边距和高度不变
29     subView.autoresizingMask = UIViewAutoresizingFlexibleWidth|UIViewAutoresizingFlexibleLeftMargin;
30 //  7、设置subView随superView的bounds变化,右边距和宽都随superView的变化而变化,而上、下、左边距和高度不变
31     subView.autoresizingMask = UIViewAutoresizingFlexibleWidth|UIViewAutoresizingFlexibleRightMargin;
32 //  8、设置subView随superView的bounds变化,左、右边距和宽都随superView的变化而变化,而上、下边距和高度不变
33     subView.autoresizingMask = UIViewAutoresizingFlexibleWidth|UIViewAutoresizingFlexibleRightMargin|UIViewAutoresizingFlexibleLeftMargin;
34
35
36     subView.backgroundColor = [UIColor blackColor];
37     [superView addSubview:subView];
38
39     UIButton *btn = [[UIButton alloc] initWithFrame:CGRectMake(100, 400,100,100)];
40     [btn addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];
41     [btn setTitle:@"点我" forState:UIControlStateNormal];
42     [btn setBackgroundColor:[UIColor grayColor]];
43
44     [self.view addSubview:btn];
45 }
46
47 -(void)click:(id)sender
48 {
49     _superView.frame = CGRectMake(50, 50, 200, 200);
50 }
51 @end
  • 这里挑2个参数来说明以下吧。
  • 第19行代码的设置subView随superView的bounds变化,上、下、左、右边距和宽高都随superView的变化而变化

    superView开始的frame为(20, 20, 100, 200)点击按钮设置为(50, 50, 200, 200)

    subView的frame为(0, 20, 50, 40)

    subView开始距离superView上边距为20

    subView开始距离superView左边距为0

    subView开始距离superView下边距为140

    subView开始距离superView右边距为50

    

    调整后superView的frame为(50, 50, 200, 200)后,subView跟随变化。

    superView和之前frame相比,高度无变化,那么subView相对于superView在上下边距和高度上自然就没有相应的变化。

    而宽度从100变为200,变大了一倍,那么相应的subView相对于superView在左右边距和宽度上也要增加一倍。

    subView距离superView上边距依旧为20*1

    subView距离superView左边距为0*2

    subView距离superView下边距为140*1

    subView距离superView右边距为50*2

    subView的高度为40*1

    subView的宽度为50*2

  • 第29行代码设置subView随superView的bounds变化,左边距和宽都随superView的变化而变化,而上、下、右边距和高度不变

     superView开始的frame为(20, 20, 100, 200)点击按钮设置为(50, 50, 200, 200)

    subView的frame为(0, 20, 50, 40)

    subView开始距离superView上边距为20

    subView开始距离superView左边距为0

    subView开始距离superView下边距为140

    subView开始距离superView右边距为50

    

    调整后superView的frame为(50, 50, 200, 200)后,subView跟随变化。

    superView和之前frame相比,高度无变化,那么subView相对于superView在上下边距和高度上自然就没有相应的变化。

    而宽度从100变为200,变大了一倍,且subView和superView的右边距要保持不变左边距和宽度就需要重新计算。

    那么从100变为200的实际变化其实就要忽略原有的右边距(其实可以这样去理解,不跟随变化的属性在计算过程中直接减掉对应值在计算变化的倍数)那么就应该是从(100-50)-(200-50)=1/3那么右边距和宽度都应该是之前变化的3倍数。

    *(100-50)原来宽度减去固定的距右边距;(200-50)变化后宽度减去固定的距右边距。

    subView距离superView上边距依旧为20*1

    subView距离superView左边距为0*3

    subView距离superView下边距为140*1

    subView距离superView右边距为50*1

    subView的高度为40*1

    subView的宽度为50*3

以上为本人对autoresizingMask属性的理解,如果有错误或者不足的地方欢迎指出。(也可加本人QQ627306590交流,望多多指教。)

    

时间: 2024-12-06 05:13:00

iOS8 UIView之autoresizingMask 的使用的相关文章

UIView的autoresizingMask属性的使用

在iOS应用的开发过程中,经常会使用,setFrame的方式对UIView进行布局, 经常会使用计算的方式,如self.view.bounds.size.height - 20-44- Heignt等来计算Y的相对位置 我们知道上边的数字 20是status bar的高度,44是navigationBar的高度. 这样的写法没有什么错误,但是不利于代码的复用,比如一个ViewController在创建的时候,有可能有navigationController,也可能没有navigationCont

UIView的autoresizingMask和autoresizesSubviews属性的剖析

UIVIew的autoresizingMask和autoresizesSubviews属性的剖析 和frame.bounds.center.transform等属性一样,autoresizingMask和autoresizesSubviews也是属于UIView的几何分类-UIViewGeometry中的属性. @property(nonatomic) BOOL autoresizesSubviews; // default is YES. if set, subviews are adjust

格而知之2:UIView的autoresizingMask属性探究

UIView的autoresizingMask属性,是用在当一个UIView实例的父控件的尺寸发生变化时,来自动调整UIView实例在父控件中的位置与尺寸的.autoresizingMask属性是一个枚举值,它的枚举成员如下: 它通过使UIView的上.下.左.右.宽度或高度自动变化来调整.下面分几种情况来讨论这个属性,假设父控件为backgroundView,子控件为subView: 1.当没有使用autoresizingMask属性或autoresizingMask属性的值为UIViewAu

关于UIView的autoresizingMask属性的研究

在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. UIViewAutoresizingNone就是不自动调整.UIViewAutoresizingFlexibleLeftMargin 自动调整与superView左边的距离,保证与superView右边的距离不变.UIViewAutoresizingFlexibleRightMargin 自动调整与superView的右边距离,保证与super

关于UIView的autoresizingMask属性的研究【转】

在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum {    UIViewAutoresizingNone                 = 0,    UIViewAutoresizingFlexibleLeftMargin   = 1 << 0,    UIViewAutoresizingFlexibleWidth        = 1 &l

UIView的autoresizingMask属性

今天做相册列表的时候,发现有些 UITableViewController 属性不好记忆,然后就查找了一些资料.做一下备份. 在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. enum { UIViewAutoresizingNone = 0, UIViewAutoresizingFlexibleLeftMargin = 1 << 0, UIViewAutoresizingFlexibleW

转-关于UIView的autoresizingMask属性的研究

在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum {    UIViewAutoresizingNone                 = 0,    UIViewAutoresizingFlexibleLeftMargin   = 1 << 0,    UIViewAutoresizingFlexibleWidth        = 1 &l

ios开发之--关于UIView的autoresizingMask属性的研究

在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. enum { UIViewAutoresizingNone = 0, UIViewAutoresizingFlexibleLeftMargin = 1 << 0, UIViewAutoresizingFlexibleWidth = 1 << 1, UIViewAutoresizingFlexibleRightMargin = 1

UIView属性

UIView属性 autoresizingMask 自动调整子控件与父控件中间的位置,宽高. UIViewAutoresizingNone就是不自动调整. UIViewAutoresizingFlexibleLeftMargin 自动调整与superView左边的距离,保证与superView右边的距离不变. UIViewAutoresizingFlexibleRightMargin 自动调整与superView的右边距离,保证与superView左边的距离不变. UIViewAutoresiz