美死你淘宝优惠券
找色差小游戏
首页 » 技术 » iOS

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

作者: 纯金 来源: 怪哈哈网 日期: 2019-04-10 17:29:20 人气: -

控件的层级关系和你加入到父视图的顺序有关,也就是先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)后添加,在上面

    1
    2
    3
    4
    5
    6
    7
    8
    9

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

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];

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18

这里写图片描述
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)

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19

它的效果这里不再说,效果和Objective-C的一样,读者也可以自己试一下。
---------------------  
作者:xiaojin38  
来源:CSDN  
原文:https://blog.csdn.net/xiaojinit/article/details/56842894  
版权声明:本文为博主原创文章,转载请附上博文链接!

转载请注明文章来源(欢迎分享): http://www.guaihaha.com/ios/22545.html

美死你优惠券网
2048小游戏
COS大全
粉象生活
关于怪哈哈
怪哈哈是一个集搞笑,美女,动漫,游戏,技术等为核心的综合性网站!
联系我们
商务洽谈、广告合作、友情链接、侵权举报,这些都可以联系我们哦!
关于我们 - 联系我们 - 广告服务 - 免责申明
本站文字和图片均为严格审查筛选收藏,均收集整理于互联网,其著作权归原作者所有,如果有侵犯您权利的照片,请来信告知,我们将及时撤销相应文字和图片.
Copyright @2014-2020 怪哈哈网 All Rights Reserved.