




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
北京尚学堂提供原理:IOS6.0 之后,苹果优化了UI界面的布局方式,提出了自动布局的概念,和之前的autoresizing相比功能更强大。子视图基于父视图的自动布局显示。都是父视图去添加对子视图的约束。在这里主要说的是通过代码对自动布局视图的实现。代码中一般用到的有两个添加约束的方式:1.- (void)addConstraint:(NSLayoutConstraint *)constraint NS_AVAILABLE_IOS(6_0);2.- (void)addConstraints:(NSArray *)constraints NS_AVAILABLE_IOS(6_0);在使用自动布局之前要对子视图的布局方式进行调整,用到这个UIView的属性。- (BOOL)translatesAutoresizingMaskIntoConstraints NS_AVAILABLE_IOS(6_0); / Default YES需要将其设置为NO;下面用简单例子说明一下:UIView *v1 = UIView alloc initWithFrame:CGRectZero;v1.translatesAutoresizingMaskIntoConstraints = NO;v1.backgroundColor = UIColor redColor;self.view addSubview:v1;UIView *v2 = UIView alloc initWithFrame:CGRectZero;v2.backgroundColor = UIColor grayColor;v2.translatesAutoresizingMaskIntoConstraints = NO;self.view addSubview:v2;/添加两个允许自动布局的子视图self.view addConstraint:NSLayoutConstraint constraintWithItem:v1attribute:NSLayoutAttributeWidthrelatedBy:NSLayoutRelationEqualtoItem:self.viewattribute:NSLayoutAttributeWidthmultiplier:1.0constant:0;/设置子视图的宽度和父视图的宽度相同self.view addConstraint:NSLayoutConstraint constraintWithItem:v1attribute:NSLayoutAttributeHeightrelatedBy:NSLayoutRelationEqualtoItem:self.viewattribute:NSLayoutAttributeHeightmultiplier:0.5constant:0;/设置子视图的高度是父视图高度的一半self.view addConstraints:NSLayoutConstraint constraintsWithVisualFormat:H:|-0-v1v2(=v1)-0-| options:0 metrics:nil views:views;/通过addConstraints 添加对水平方向上v1的控制-距离父视图左侧距离为0(距离为0的话也可省略)同时将v2的水平方向的宽度和v1设置成相同self.view addConstraints:NSLayoutConstraint constraintsWithVisualFormat: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 metrics:nil views:views;/最后是垂直布局两个子view这样就可以实现上下两个view,各占一半。旋转屏幕的情况下也会自动处理布局。这样看起来代码多,但是可以适应多种分辨率的屏幕。不排除以后苹果出更大更多分辨率的手机。关于constraintsWithVisualFormat:函数介绍:constraintsWithVisualFormat:参数为NSString型,指定Contsraint的属性,是垂直方向的限定还是水平方向的限定,参数定义一般如下:V:|-(=XXX) :表示垂直方向上相对于SuperView大于、等于、小于某个距离若是要定义水平方向,则将V:改成H:即可在接着后面-中括号里面对当前的View/控件 的高度/宽度进行设定;options:字典类型的值;这里的值一般在系统定义的一个enum里面选取metrics:nil;一般为nil ,参数类型为NSDictionary,从外部传入 /衡量标准views:就是上面所加入到NSDictionary中的绑定的View在这里要注意的是 AddConstraints和 AddConstraint 之间的区别,一个添加的参数是NSArray,一个是NSLayoutConstraint使用规则|: 表示父视图-:表示距离V:表示垂直H:表示水平= :表示视图间距、宽度和高度必须大于或等于某个值=、=0-button-(=padding)-| : 表示离父视图的距离为Padding,这两个视图间距必须大于或等于0并且距离底部父视图为 padding。10:wideView(=60700):视图的宽度为至少为60 不能超过70011: 如果没有声明方向默认为水平V:【最新文档更新请加入尚学堂www.sxt.
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 宿州宿城第一初级中学教育集团教师招聘考试真题2024
- 保定市唐县招聘社区工作者考试真题2024
- 电势考试题及答案
- 乞丐考试题及答案
- 中式面点制作技艺智慧树答案
- 护理管理基础模拟考试题(附答案)
- 中外教育史(长青联盟)知到智慧树答案
- 小儿上呼吸道感染的健康教育与心理护理培训考试题(含答案)
- 幼儿园食品安全知识测试题(附答案)
- 十二导心电图机应用培训考核试题(附答案)
- 从力的做功到平面向量数量积说课稿省名师优质课赛课获奖课件市赛课百校联赛优质课一等奖课件
- 铝合金压铸控制计划模板
- 肿瘤和肾脏病
- 数字电路逻辑设计(第3版)PPT全套完整教学课件
- 工程竣工验收单(简易版)
- 社会学导论(第五版)孙立平课件
- (3.1)-第6讲理解列车进路和调车进路
- SB/T 10967-2013红辣椒干流通规范
- GB/T 12755-1991建筑用压型钢板
- DL-T 5190.1-2022 电力建设施工技术规范 第1部分:土建结构工程(附条文说明)
- 《国际结算(第五版)》第八章 供应链金融1907
评论
0/150
提交评论