您的位置:首页 > 移动开发 > IOS开发

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

2017-02-24 15:44 2071 查看
控件的层级关系和你加入到父视图的顺序有关,也就是先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的一样,读者也可以自己试一下。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐