详解ios中frame和bounds的区别

2016-02-24  本文已影响296人  统领三界

在ios中有的控件有frame和bound两个属性,这两个属性的参数非常相似

    aview.frame = CGRectMake(CGFloat x, CGFloat y, CGFloat 
width, CGFloat height)

    aview.bounds = CGRectMake(CGFloat x, CGFloat y, 
CGFloat width, CGFloat height)

两者的共同点是后面两个参数都是设置控件的大小,区别是前两个参数,对于frame来说,CGFloat x, CGFloat y,两个参数是aview相对于父视图的位置,二bounds是aview上面的子视图在aview上面的起始位置.我们用代码看下效果
添加两个view分别是aview 和bview 其中aview添加到背景上面,bview作为子视图添加到aview上面.

  UIView *aview = [[UIView alloc]init];
    aview.backgroundColor = [UIColor redColor];
    aview.frame = CGRectMake(100, 100, 200, 200);
    [self.view addSubview:aview];


9E172A2F-859C-4DB7-B561-5AF2B477752F.png

下面我们添加bview

UIView *bview = [[UIView alloc]initWithFrame:CGRectMake(0, 0, 100, 100)];
bview.backgroundColor = [UIColor grayColor];
[aview addSubview:bview];

效果如下图

E71B3B88-1DCC-487B-8F09-08E796BD363C.png

前面我们说了frame的前面两个参数 是相对于父视图的位置,如果我们没有设置父视图aview的bound 那我们默认的参考系原点就是父视图的左上角的起始位置

下面我们修改下父视图aview的bounds看看会有什么变化

    aview.bounds = CGRectMake(50, 50, 200, 200);

修改之后效果如下

75AE8982-D800-48FA-9039-C9FA1C7F0B29.png

可以看到这个bview的位置发生了变化,相对于原来的原点分辨向上向左移动了50的距离.

如果改变下前面两个值

    aview.bounds = CGRectMake(-50, -50, 200, 200);

效果如下


526FA5D6-FC00-467D-B946-7A6AD640B6EF.png
上一篇 下一篇

猜你喜欢

热点阅读