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的情况:
如图:
修改成如下代码:
2.Swift的情况
它的效果这里不再说,效果和Objective-C的一样,读者也可以自己试一下。
可以通过以下函数改变子视图的层级:
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的一样,读者也可以自己试一下。
相关文章推荐
- IOS开发之UIScrollView的属性总结
- ios开发中对UITableView的操作(包括删除,插入,移动位置)
- 【iOS开发-9】UIImage和UIImageView属性介绍,实现图片动画,实现开始/停止按钮效果
- 转载: ios开发之View属性hidden, opaque, alpha的区别
- iOS开发 剖析网易新闻标签栏视图切换(addChildViewController属性介绍)
- IOS应用开发中的tips - MKMapView之设置地图以用户当前位置为中心
- ios开发 - UIImageView 的contentMode属性应用
- 【iOS开发-10】UIProgressView进度条的几个属性介绍
- iOS开发 剖析网易新闻标签栏视图切换(addChildViewController属性介绍)
- iOS开发 剖析网易新闻标签栏视图切换(addChildViewController属性介绍)
- 给iOS开发新手送点福利,简述UIActivityIndicatorView的属性和用法
- IOS 表视图(UITableVIew)的使用方法(7)表视图的编辑功能(拖拉调整排序位置)
- 给iOS开发新手送点福利,简述UIScrollView的属性和用法
- 【iOS开发-14】UIView的属性,父视图和子视图的层级操作,子视图的自适应模式,外加一个定时器
- IOS开发(8)之调整ViewController的序列
- 给iOS开发新手送点福利,简述UIAlertView的属性和用法
- ios开发---view的frame和bounds之区别(位置和大小)
- IOS学习笔记(十二)之IOS开发之表视图(UITableView)的相关类,属性与表视图实现学习(二)
- iOS开发——View的透明属性hidden、alpha、opaque
- 【iOS开发-16】UITextField协议的用法,键盘的隐藏,以及视图随着键盘的出现隐藏而上下调整位置