iOS开发中,调整view层级位置的两个属性

来源:互联网 发布:ubuntu txt中文乱码 编辑:程序博客网 时间:2024/04/29 17:55

控件的层级关系和你加入到父视图的顺序有关,也就是先addsubview至父视图的,层级越低,会被后加入的遮盖。
可以通过以下函数改变子视图的层级:

1.Objective-C版本:
将UIView显示在最前面:
- (void)bringSubviewToFront:(UIView *)view;

将UIView显示在下面:
- (void)sendSubviewToBack:(UIView *)view;

2.Swift版本:
将UIView显示在最前面:
open func bringSubview(toFront view: UIView)

将UIView显示在下面:
open func sendSubview(toBack view: UIView)

下面我们来举个实例:
1.Objective-C的情况:

UIView *view1 = [[UIView alloc] initWithFrame:CGRectMake(100, 150, 100, 100)];    view1.backgroundColor = [UIColor redColor];    [self.view addSubview:view1];    UIView *view2 = [[UIView alloc] initWithFrame:CGRectMake(150, 200, 100, 100)];    view2.backgroundColor = [UIColor greenColor];    [self.view addSubview:view2];    // 以上显示:红色视图(view1)先添加,在下面,绿色视图(view2)后添加,在上面

如图:这里写图片描述
修改成如下代码:

UIView *view1 = [[UIView alloc] initWithFrame:CGRectMake(100, 150, 100, 100)];    view1.backgroundColor = [UIColor redColor];    [self.view addSubview:view1];    UIView *view2 = [[UIView alloc] initWithFrame:CGRectMake(150, 200, 100, 100)];    view2.backgroundColor = [UIColor greenColor];    [self.view addSubview:view2];    // 以上显示:红色视图(view1)先添加,在下面,绿色视图(view2)后添加,在上面    // 添加如下修改层级的代码    // 将view2放在最下方    [self.view sendSubviewToBack:view2];    // 将view1放在最上方    [self.view bringSubviewToFront:view1];

这里写图片描述
2.Swift的情况

let view1 = UIView(frame: CGRect(x: 100, y: 150, width: 100, height: 100))        view1.backgroundColor = UIColor.red        self.view.addSubview(view1)        let view2 = UIView(frame: CGRect(x: 150, y: 200, width: 100, height: 100))        view2.backgroundColor = UIColor.green;        self.view.addSubview(view2)        // 以上显示:红色视图(view1)先添加,在下面,绿色视图(view2)后添加,在上面        // 添加如下修改层级的代码        // 将view2放在最下方        self.view.sendSubview(toBack: view2)        // 将view1放在最上方        self.view.bringSubview(toFront: view1)

它的效果这里不再说,效果和Objective-C的一样,读者也可以自己试一下。

0 0
原创粉丝点击