自动布局AutoLayout
1:理解概念
Auto Layout 中文翻译过来意思是 自动布局 ,通过内定的 Constraint (约束)和各项条件来计算出合理的布局.而这个合理的布局,符合我们的的预期和意图.
将我们想象中的结果展现出来. Constraint 的设定非常灵活,实现一种布局的方法可以通过多Constraint 套来完成.
以下几点是我们在开始使用之前必须弄清楚的事情:
1:我们要抛弃以往旧的布局方式不再去关注View的Frame,Center,和autoresizing. 因为这些坐标和大小的定位都可以通过来Auto Layout完成.
2:理解每一种 Constraint 的含义,否则,当你去看别人的实现的 Constraint 时,就会有种看天书的感觉.
3:按意图设计,一切按我们理想中的效果去布局,只要约束设定的合理,就一定能够完成目标布局.
2:开始使用
先从 Interface Builder 开始吧. 打开某个 Xib 或者 StoryBoard ,
在右侧 Show in file inspector 里面找到 Ues Autolayout ,将其勾选.如下图:

自此, Autolayout 便启用成功, autoresizingMask 被废弃.其所有以往的功能和特性都被Autolayout 取代.
现在我们定位控件位置的 方式 ,不再像以前一样, 计算 好每一个控件具体的位置,x是多少,y是多少.
而是思考,这个控件离左边是相隔多少距离,或者离顶部或底部相隔多少距离.
而有些规则性的事情还是类似的,比如我们定位一个控制的位置,一定要有x,y两个坐标点同时有值,少一个都不能正常显示.
同样 Autolayout 在创建约束时也一样,在思考完离顶部距离以后,还需要思考离顶部距离,否则控件的显示位置一样无法正常显示.
换言之,要让 Autolayout 计算出合理的位置,需要保证 水平 距离和 垂直 距离同时存在. 否则IDE,都会给出警告,提示这样的布局 Ambiguous Layout (模凌两可)
接下来,让我们来熟悉一下 Interface Builder 提供哪些实现 Autolayout 的功能:
观察一下界面预览右下角,有一排如下图这样的按钮:

这些是 Interface Builder 用来创建 Constraint 的主要方式,同时,我们也可以在 Xcode 的菜单栏中找到这些功能,如下图:

这些功能分别如下图中描述的那样:


如果是从代码层面开始使用Autolayout,需要对使用的View的translatesAutoresizingMaskIntoConstraints 的属性设置为NO.
即可开始通过代码添加Constraint,否则View还是会按照以往的autoresizingMask进行计算.
而在 Interface Builder 中勾选了Ues Autolayout,IB生成的控件的translatesAutoresizingMaskIntoConstraints 属性都会被默认设置NO.
3:从旧的IB布局中转换成Auto layout
4:熟练使用Interface Builder
5:通过代码来构建自动布局
代码创建的约束有两种方式:
1:常规约束,写法非常冗长,但能实现所有的约束方式以及非常特殊的约束方式,代码如下:
//添加两个允许自动布局的子视图
UIView *view1 = [[UIView alloc]initWithFrame:CGRectZero];
//使用Autolayout,关闭Autorisizing
view1.translatesAutoresizingMaskIntoConstraints = NO;
view1.backgroundColor = [UIColor redColor];
[self.view addSubview:view1]; UIView *view2 = [UIView new];
view2.frame = CGRectZero;
view2.translatesAutoresizingMaskIntoConstraints = NO;
view2.backgroundColor = [UIColor grayColor];
[self.view addSubview:view2];
/**
* 第一种简单方法
*/
//设置子视图的宽度和父视图的宽度相同
// [self.view addConstraint:
// //添加一个约束
// [NSLayoutConstraint constraintWithItem:
// //给谁添加约束(view1)
// view1 attribute:
// //约束的属性是宽
// NSLayoutAttributeWidth relatedBy:
// //约束的关系是怎样的,相等,还是大于小于
// NSLayoutRelationEqual toItem:
// //和谁建立约束关系(父视图)
// self.view attribute:
// //和父视图的哪个属性建立
// NSLayoutAttributeWidth multiplier:
// //比例
// 1.0 constant:
// //约束的值
// -100]];
//“view1.attr1 = view2.attr2 * multiplier + constant” //设置子视图的高度是父视图高度的一半
// [self.view addConstraint:[NSLayoutConstraint
constraintWithItem:view1
attribute:NSLayoutAttributeHeight
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeHeight
multiplier:0.5
constant:-
]
]; //////////////////////////////////////////////////////////////////////////////////////// #import "DDYViewController.h"
#define SCREENW [UIScreen mainScreen].bounds.size.width
#define SCREENH [UIScreen mainScreen].bounds.size.height @interface DDYViewController () @property (nonatomic, weak)UITextField *loginName; @end @implementation DDYViewController - (void)viewDidLoad {
[super viewDidLoad]; self.view.backgroundColor = [UIColor lightGrayColor]; //imageView 背景图片
[self settingImageView]; //texdField 文本框
[self settingTextField]; } #pragma mark - texdField
- (void)settingTextField
{
//创建组件
UITextField *loginName = [[UITextField alloc]init]; //设置frame,约束完删除
//loginName.frame = CGRectMake(10, 10, 100, 30); //用autolayout
loginName.translatesAutoresizingMaskIntoConstraints = NO; //文本颜色
loginName.textColor = [UIColor blueColor]; //背景颜色
loginName.backgroundColor = [UIColor whiteColor]; //默认显示
loginName.placeholder = @"password"; //样式
[loginName setBorderStyle:UITextBorderStyleRoundedRect]; //全局
_loginName = loginName; //添加组件
[self.view addSubview:loginName]; /* 约束 */
[self.view addConstraint:[NSLayoutConstraint
constraintWithItem:loginName
attribute:NSLayoutAttributeHeight
relatedBy:NSLayoutRelationEqual
toItem:nil
attribute:NSLayoutAttributeNotAnAttribute
multiplier:
constant:
]
]; [self.view addConstraint:[NSLayoutConstraint
constraintWithItem:loginName
attribute:NSLayoutAttributeWidth
relatedBy:NSLayoutRelationEqual
toItem:nil
attribute:NSLayoutAttributeNotAnAttribute
multiplier:
constant:
]
];
[self.view addConstraint:[NSLayoutConstraint
constraintWithItem:loginName
attribute:NSLayoutAttributeTop
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeTop
multiplier:
constant:
]
];
[self.view addConstraint:[NSLayoutConstraint
constraintWithItem:loginName
attribute:NSLayoutAttributeCenterX
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeCenterX
multiplier:
constant:
]
];
} #pragma mark - imageView
- (void)settingImageView {
//创建组件
UIImageView *backImageView = [[UIImageView alloc]init]; //背景色,无背景图片时可用
//backImageView.backgroundColor = [UIColor grayColor]; //背景图片
backImageView.image = [UIImage imageNamed:@"form-big"]; //开启用户交互,往其上添加可交互组件时开启
//backImageView.userInteractionEnabled = YES; //添加组价
[self.view addSubview:backImageView]; //使用autolayout
backImageView.translatesAutoresizingMaskIntoConstraints = NO; /* 约束 */
[self.view addConstraint:[NSLayoutConstraint
constraintWithItem:backImageView
attribute:NSLayoutAttributeHeight
relatedBy:NSLayoutRelationEqual
toItem:nil
attribute:NSLayoutAttributeNotAnAttribute
multiplier:
constant:
]
]; [self.view addConstraint:[NSLayoutConstraint
constraintWithItem:backImageView
attribute:NSLayoutAttributeWidth
relatedBy:NSLayoutRelationEqual
toItem:nil
attribute:NSLayoutAttributeNotAnAttribute
multiplier:
constant:
]
];
[self.view addConstraint:[NSLayoutConstraint
constraintWithItem:backImageView
attribute:NSLayoutAttributeTop
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeTop
multiplier:
constant:
]
];
[self.view addConstraint:[NSLayoutConstraint
constraintWithItem:backImageView
attribute:NSLayoutAttributeCenterX
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeCenterX
multiplier:
constant:
]
];
}
item1.attribute = multiplier ⨉ item2.attribute + constant
2:可视化格式语言约束VFL
/**
* 第二种方法
*/
//NSDictionaryOfVariableBindings是一个宏定义,期作用是生成一个字典,key的名字和对象的名字标示符相同,比如{@“self.view”:self.view ,@“view1”:view1,@“view2”:view2},一般字典里包含需要自动布局的父视图和所有的子视图
NSDictionary *views = NSDictionaryOfVariableBindings(self.view,view1,view2); [self.view addConstraints:
//添加一组约束
[NSLayoutConstraint constraintsWithVisualFormat:
//添加对水平方向上V1的控制:距离父视图左边距为0(如果是0可以忽略),同时view2的宽度和viwe1相同
@“H:|--[view1]--[view2(==view1)]--|” options:
//字典类型的值,可以点进去看枚举类型,一般给0
metrics:
//衡量标准,一般为nil,参数从NSDictionary传过来
nil views:views]]; // [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@“V:|-100-[view1]-100-|” options:0 metrics:nil views:views]];
// [self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@“V:|-100-[view2]-100-|” options:0 metrics:nil views:views]]; //添加垂直方向view1的控制:距离父视图顶部距离为0;同时viwe2的高度和view1相等
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@“V:|--[view1]--[view2(==view1)]--|” options: metrics:nil views:views]];
自动布局AutoLayout的更多相关文章
- Xcode6中自动布局autolayout和sizeclass的使用
Xcode6中自动布局autolayout和sizeclass的使用 一.关于自动布局(Autolayout) 在Xcode中,自动布局看似是一个很复杂的系统,在真正使用它之前,我也是这么认为的, ...
- (转)Xcode6中自动布局autolayout和sizeclass的使用
Xcode6中自动布局autolayout和sizeclass的使用 一.关于自动布局(Autolayout) 在Xcode中,自动布局看似是一个很复杂的系统,在真正使用它之前,我也是这么认为的, ...
- iOS:自动布局Autolayout
自动布局:Autolayout 简介: 在以前的iOS程序中,是如何设置布局UI界面的? 经常编写大量的坐标计算代码 为了保证在3.5 inch和4.0 inch屏幕上都能有完美的UI界面效果,有时还 ...
- 自动布局autolayout和sizeclass的使用
一.关于自动布局(Autolayout) 在Xcode中,自动布局看似是一个很复杂的系统,在真正使用它之前,我也是这么认为的,不过事实并非如此. 我们知道,一款iOS应用,其主要UI组件是由一个个相对 ...
- iOS 自动布局 Autolayout 优先级的使用
一.约束的优先级 0.屏幕适配 发展历程 代码计算frame -> autoreszing(父控件和子控件的关系) -> autolayout(任何控件都可以产生关系) -> siz ...
- IOS手动添加的View 在代码中使用(自动布局)autoLayout
- (void)viewDidLoad { [super viewDidLoad]; UIButton *btnTest = [UIButton buttonWithType:UIButtonType ...
- iOS-自动布局Autolayout(原创)
前言 基础知识 在一定情况下我们需要用到自动布局(autolayout) 这样我们就能使视图与视图之间的位置相互关联起来 横向:距离父视图左侧100 视图本身的宽度最小是100 距离父视图右侧是100 ...
- 【转】iOS学习之Storyboard中的UIScrollView使用自动布局
在使用storyboard和xib时,我们经常要用到ScrollView,还有自动布局AutoLayout,但是ScrollView和AutoLayout 结合使用,相对来说有点复杂.根据实践,我说一 ...
- AutoLayout +Masonary
1, Masonry介绍与使用实践(快速上手Autolayout) http://adad184.com/2014/09/28/use-masonry-to-quick-solve-autolayou ...
随机推荐
- ios7--系统自带的向右滑动手势返回上一个界面
当从控制器A push到控制器B,我们返回控制器A,除了使用按钮返回 [self.navigationController pushViewController:Vc animated:YES]; 还 ...
- Köln-keith jarrett
在火车上遇到一男生,带着他弟弟.他弟弟跑来跑去的,他就安稳地坐在下铺看书,不知道是哪种语言. 我们都是在北京下车. 第二天在王府井吃饭,姐姐带我吃西餐.我又看到他,跟一个阿姨一起吃饭. 吃饭的时候姐姐 ...
- STP根交换机,指定端口,根端口,阻塞端口
STP判断各交换机端口(指定端口:DP;根端口:RP;阻塞端口:AP) 判断步骤: 1.选举根交换机: 判断对象:所有运行STP协议的交换机中选出一个; 判断依据:交换机中选择网桥ID值(交换机优先级 ...
- ecmall数据库基本操作
ecmall数据库基本操作,为了认真研究ecmall二次开发,我们必须熟悉ecamll的数据库结构,ecmall数据库结构研究熟悉之后,才能去认真分析ecamll的程序结构.从而实现ecmall二次开 ...
- Windows phone常用控件之Button
Button类:表示一个响应 ButtonBase.Click 事件的 Windows 按钮控件. 继承层次结构: 命名空间: System.Windows.Controls ClickMode ...
- Windows下面对环境变量的操作
如何在cmd命令行中查看.修改.删除与添加环境变量:首先明确一点:所有的在cmd命令行下对环境变量的修改只对当前窗口有效,不是永久性的修改.也就是说当关闭此cmd命令行窗口后,将不再起作用.永久性修改 ...
- CANoe 入门 Step by step系列(二)CAPL编程【转】
CAPL就是Communication Application Programming Laguage的缩写,CAPL类似于C语言的语法,因此所有的语法请参考C语言教程,这里不在这里进行详述,关于C语 ...
- Python【第十篇】协程、异步IO
大纲 Gevent协程 阻塞IO和非阻塞IO.同步IO和异步IO的区别 事件驱动.IO多路复用(select/poll/epoll) 1.协程 1.1协程的概念 协程,又称微线程,纤程.英文名Coro ...
- iOS: 学习笔记, Swift与C指针交互(译)
Swift与C指针交互 Objective-C和C API经常需要使用指针. 在设计上, Swift数据类型可以自然的与基于指针的Cocoa API一起工作, Swift自动处理几种常用的指针参数. ...
- 我学C的那些年[ch02]:宏,结构体,typedef
c语言的编译过程: 预处理 编译 汇编 链接 而预处理中有三种情况: 文件包含( #include ) 条件编译(#if,#ifndef,#endif) 宏定义( #define ) 宏就是预处理中的 ...