下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、北京尚学堂提供原理:IOS6.0 之后,苹果优化了UI界面的布局方式,提出了自动布局的概念,和之前的autoresizing相比功能更强大。子视图基于父视图的自动布局显示。都是父视图去添加对子视图的约束。在这里主要说的是通过代码对自动布局视图的实现。代码中一般用到的有两个添加约束的方式:1.- (void)addConstraint:(NSLayoutConstraint *)constraint NS_AVAILABLE_IOS(6_0);2.- (void)addConstraints:(NSArray *)constraints NS_AVAILABLE_IOS(6_0);<<
2、;/span>在使用自动布局之前要对子视图的布局方式进行调整,用到这个UIView的属性。- (BOOL)translatesAutoresizingMaskIntoConstraints NS_AVAILABLE_IOS(6_0); / Default YES需要将其设置为NO;下面用简单例子说明一下: UIView *v1 = UIView alloc initWithFrame:CGRectZero; v1.translatesAutoresizingMaskIntoConstraints = NO; &
3、#160; v1.backgroundColor = UIColor redColor; self.view addSubview:v1; UIView *v2 = UIView alloc initWithFrame:CGRectZero; v2.backgroundColor = UIColor grayColor; v2.translatesAutoresizingMaskIntoCo
4、nstraints = NO; self.view addSubview:v2;/添加两个允许自动布局的子视图 self.view addConstraint:NSLayoutConstraint constraintWithItem:v1
5、160; attribute:NSLayoutAttributeWidth
6、 relatedBy:NS
7、LayoutRelationEqual
8、; toItem:self.view &
9、#160; attribute:NSLayoutAttributeWidth
10、; multiplier:1.0
11、60; constant:
12、0;/设置子视图的宽度和父视图的宽度相同 self.view addConstraint:NSLayoutConstraint constraintWithItem:v1
13、 attribute:NSLayoutAttributeHeight
14、60; relatedBy:NSLayoutRelationEqual
15、160;
16、160; toItem:self.view
17、0; attribute:NSLayoutAttributeHeight &
18、#160; multiplier:0.5
19、; constant:0;/设置子视图的高度是父视图高度的一半 self.view ad
20、dConstraints:NSLayoutConstraint constraintsWithVisualFormat:"H:|-0-v1v2(=v1)-0-|" options:0 metrics:nil views:views;/通过addConstraints 添加对水平方向上v1的控制-距离父视图左侧距离为0(距离为0的话也可省略)同时将v2的水平方向的宽度和v1设置成相同 self.view addConstraints:NSLayoutConstraint constraintsWithVisualFormat:&q
21、uot;V:|-0-v1v2(=v1)|" options:0 metrics:nil views:views;/通过addConstraints 添加对垂直方向上v1的控制-距离父视图上侧距离为0(距离为0的话也可省略)同时将v2的垂直方向的高度和v1设置成相同 self.view addConstraints:NSLayoutConstraint constraintsWithVisualFormat:"V:|-0-v1-0-v2-0-|" options:0 met
22、rics:nil views:views;/最后是垂直布局两个子view这样就可以实现上下两个view,各占一半。旋转屏幕的情况下也会自动处理布局。这样看起来代码多,但是可以适应多种分辨率的屏幕。不排除以后苹果出更大更多分辨率的手机。关于constraintsWithVisualFormat:函数介绍:constraintsWithVisualFormat:参数为NSString型,指定Contsraint的属性,是垂直方向的限定还是水平方向的限定,参数定义一般如下:V:|-(>=XXX) :表示垂直方向上相对于SuperView大于、等于、小于某个距离若是要定义水平方向,则将V:改成H
23、:即可在接着后面-中括号里面对当前的View/控件 的高度/宽度进行设定;options:字典类型的值;这里的值一般在系统定义的一个enum里面选取metrics:nil;一般为nil ,参数类型为NSDictionary,从外部传入 /衡量标准views:就是上面所加入到NSDictionary中的绑定的View在这里要注意的是 AddConstraints 和 AddConstraint 之间的区别,一个添加的参数是NSArray,一个是NSLayoutConstraint使用规则|: 表示父视图 -:表示距离 V: :表示垂直 H: :表示水平>= :表示视图间距、宽度和高度必须大于或等于某个值 <= :表示视
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 湿气重体质的饮食安排
- 经期不适的饮食调节
- 员工设备维护课件
- 2025年网络接口适配器项目合作计划书
- 2025年抗结剂项目建议书
- 太阳能建筑一体化原理与应 课件 第10、11章 太阳能空调、太阳能与建筑围护结构的一体化
- 牙周炎的成因及危害分析
- 烧伤患者静脉通路护理
- 综合护理能力比武课件制作
- 呼吸衰竭的护理经济管理
- 潘谢矿区西淝河、泥河、济河、港河水体下安全开采可行性论证报告
- 本田供应商品质监查1
- 创业人生(上海大学)【超星尔雅学习通】章节答案
- 开放系统10862人文英语(4)期末机考真题及答案
- GB/T 4957-2003非磁性基体金属上非导电覆盖层覆盖层厚度测量涡流法
- GB/T 27806-2011环氧沥青防腐涂料
- GB/T 12618.1-2006开口型平圆头抽芯铆钉10、11级
- FZ/T 52051-2018低熔点聚酯(LMPET)/聚酯(PET)复合短纤维
- 设备吊装方案编制受力计算
- 食品工程原理概述经典课件
- 养老院机构组织架构图
评论
0/150
提交评论