1. iOS两种自适应布局方式:(修正说明:)

-AutoLayout(自动布局) + SizeClasses(尺寸类别)

-Autoresizing (自动调整尺寸/弹簧式调整尺寸)

前者 AutoLayout 是从iOS6出现,通过创建视图约束实现自适应,SizeClasses是iOS8 开始出现,用于配合AutoLayout使用,为解决所有(包括iPhone,iPad)iOS设备屏幕尺寸和屏幕旋转时UI的适配。

后者是早期开发使用的适配界面的方式,现在仍然保留。通过弹簧式调整控件尺寸,使其适应屏幕的尺寸变化。

苹果官方建议使用AutoLayout。

Autoresizing 缺点:

> 其描述界面变化规则不够灵活,很多变化规则根本无法精确描述。autoresizingMask缩放比例是UIKit内部计算的,开发者无法指定缩放比例的精确值。

  • > 变化规则只能基于父视图与子视图之间,无法建立同级视图或者跨级视图之间的关系。

AutoLayout 的核心原理:

> view具有自我计算尺寸,布局的能力。通过它自身的内容,能够得到尺寸。

> view的布局位置,确定于它与superview及其他view的关系。

> 与传统的autoresizingmask自适应相比,AutoLayout更精确,能绝对的确定view的布局。

> view不一定需要一个初始的rect。AutoLayout中,view如果有足够的constraint,便可以确定自己的尺寸和位置,并且知道自己和其他view的关系。即,想确定view的布局,就给它(们)添加constraint。

2. AutoLayout 自动布局 有三种方式:

> 在Xcode 可视化界面 Interface Builder 中右下角添加并设置约束

> 纯代码添加约束

> 纯代码通过可视化格式语言VFL(Visual Format Language) 添加约束

2.1 可视化设置约束

Interface Builder中,右下角,依次是Alignment(布局),Pin(固定),Resolve(解决约束错误)

以下列出三项中常用的项

Alignment: Horizontally in Container  在容器中水平中心,值为0,设置其他值时,表示水平方向偏移中心位置量

Vertially in Container 在容器中竖直中心,值为0,设置其他值时,表示水平方向偏移中心位置量

Pin:

上方四个值,从左侧顺时针依次是:

Leading Space to Superview // 相对于父视图的左间距 leading:首部

Top Space to Superview       // 相对于父视图的上间距

Trailing Space to Superview  // 相对于父视图的右间距 trailing:尾部

Bottom Space to Superview  // 相对于父视图的底间距

Width : 固定自身宽度

Height : 固定自身高度

若要使多个视图相同的宽度,高度,则先同时选中多个视图,然后在Pin中选择:

  EqualWidths: 多个视图相同宽度;EqualHeights: 多个视图相同高度

若要使两个视图水平方向或垂直方向上相互之间的距离固定,先选中其中一个视图,同时按住键盘上control键,拉线到另一个视图,在弹出框中:

选中 Horizontal Spacing (水平方向间距) 或 Vertical Spacing(竖直方向间距),然后在被选中视图的Size Inspector(右侧倒数第二个选项卡) 中Constraints 栏目下,如图所示: 点击“Edit”,

弹出     在 constant中输入固定间距值

Resolve: 主要使用到 Clear Constraints 清除视图的约束

2.2 纯代码设置约束

NSLayoutConstraint 布局约束类

> 纯代码方式添加视图,不指定frame(若可视化下添加其位置,大小对约束有影响,会产生冲突)

> 设置禁止自动尺寸转换成约束,否则会产生约束冲突

被约束的视图.translatesAutoresizingMaskIntoConstraints = NO

在可视化下Interface Builder 上默认设置就是关闭的

> 创建约束

[NSLayoutConstraint constraintWithItem:lb attribute:NSLayoutAttributeLeft relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeLeft multiplier:1.0 constant:100]

// 参数一:被约束的视图:view1

// 参数二:指定在被约束的视图哪个属性上约束,位置或大小

// 参数三:被约束的视图与参照视图指定属性之间的关系

// 参数四:参照视图:view2

// 参数五:参照视图的属性

// 参数六: multiplier:被约束视图指定属性是参照视图指定属性的多少倍

// 参数七:被约束视图的指定属性需要加的浮点数 value

计算公式:view1.attr [=,>=,<=] view2.attr * multiplier + value;

> 添加约束

注意:约束是添加到参照视图上。

[view2 addConstraint: ]

[扩展] 第三方库实现约束 Masonry

官网: https://github.com/SnapKit/Masonry

2.3 VFL设置约束

通过 NSLayoutConstraint 类方法:

+ (NSArray<__kindof NSLayoutConstraint *> *)constraintsWithVisualFormat:(NSString *)format options:(NSLayoutFormatOptions)opts metrics:(nullable NSDictionary<NSString *,id> *)metrics views:(NSDictionary<NSString *, id> *)views;

示例:

NSArray *constraints=[NSLayoutConstraint constraintsWithVisualFormat:@"V:[button]-[button1(==height)]"

                         options:0

                         metrics:@{@"height":@30}

                         views:NSDictionaryOfVariableBindings(button1,button2)];

AutoLayout(自动布局)的更多相关文章

  1. iOS AutoLayout自动布局&Masonry介绍与使用实践

    Masonry介绍与使用实践:快速上手Autolayout http://www.cnblogs.com/xiaofeixiang/p/5127825.html http://www.cocoachi ...

  2. iOS:Autolayout自动布局实例

    Autolayout自动布局实例即可以用故事板布局,也可以用纯代码创建,各有各的优点:用故事板布局,比较方便,而且直观,可以很直白的看到视图布局后的变化:采用代码布局,虽然代码比较多,有些麻烦,但是可 ...

  3. AutoLayout自动布局

      原文转自http://www.cnblogs.com/xjf125/p/4895978.html 目录: 一.什么是AutoLayout? 二.创建autoLayout的方法 三.VFL语言   ...

  4. 轻量级应用开发之(06)Autolayout自动布局1

    一 什么是Autolayout Autolayout是一种“自动布局”技术,专门用来布局UI界面的. 自IOS7 (Xcode 5)开始,Autolayout的开发效率得到很大的提高. 苹果官方也推荐 ...

  5. AutoLayout自动布局之VFL语言代码实现(一个神奇的语言)

    一.什么是VFL语言?为什么要VFL语言? VFL全称是Visual Format Language,翻译过来是“可视化格式语言” VFL是苹果公司为了简化Autolayout的编码而推出的抽象语言 ...

  6. AutoLayout自动布局,NSLayoutConstraint 视图约束使用

    一.方法 NSLayoutConstraint *constraint = [NSLayoutConstraint constraintWithItem:<#(id)#> attribut ...

  7. 轻量级应用开发之(06)Autolayout自动布局2

    一 Masonry 下载地址:https://github.com/SnapKit/Masonry

  8. 几种AutoLayout自动布局所经常使用的布局约束类型

    width表示约束ui控件的固定宽度 height表示约束ui控件的固定高度 Leading Space to Superview 与父视图的左边界线保持固定距离 Trailing Space to ...

  9. [OC] autoLayout 博客文档

    tip :记录几个博客文档 iOS 8 Auto Layout界面自动布局系列5-自身内容尺寸约束.修改约束.布局动画 iOS AutoLayout自动布局中级开发教程(5)-修改约束的值,延迟加载 ...

随机推荐

  1. 关于大小型项目如何最大限度提高WebAPi性能

    前言 WebAPi作为接口请求的一种服务,当我们请求该服务时我们目标是需要快速获取该服务的数据响应,这种情况在大型项目中尤为常见,此时迫切需要提高WebAPi的响应机制,当然也少不了前端需要作出的努力 ...

  2. Python快速教程 尾声

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 写了将近两年的Python快速教程,终于大概成形.这一系列文章,包括Python基 ...

  3. angularjs 请求后端接口请求了两次

    用angularjs的过程中发现,每次打开页面,请求后端的接口都请求了两次 如下图可以看到, http://192.168.1.109:8080/zdh/api/v1/goods/54 这个页面loa ...

  4. EasyUI+MVC+EF简单用户管理Demo(问题及解决)

    写在前面 iframe-src EntityFramework版本 connectionStrings View.Action.页面跳转 EasyUI中DataGrid绑定 新增.修改和删除数据 效果 ...

  5. 网络通信简单实例BIO,NIO,AIO

    这里,我将做一个简单的通信程序,分别使用三种原始的通信工具:BIO,NIO,AIO. 功能就是一个服务器,一个客户端.服务器就是处理请求,返回响应.而客户端就是连接服务器,发送请求,接收响应. 第一步 ...

  6. Cesium原理篇:3最长的一帧之地形(4:重采样)

           地形部分的原理介绍的差不多了,但之前还有一个刻意忽略的地方,就是地形的重采样.通俗的讲,如果当前Tile没有地形数据的话,则会从他父类的地形数据中取它所对应的四分之一的地形数据.打个比方 ...

  7. Kafka到Hdfs的数据Pipeline整理

    作者:Syn良子 出处:http://www.cnblogs.com/cssdongl 转载请注明出处 找时间总结整理了下数据从Kafka到Hdfs的一些pipeline,如下 1> Kafka ...

  8. 关系数据库SQL之基本数据查询:子查询、分组查询、模糊查询

    前言 上一篇关系数据库常用SQL语句语法大全主要是关系型数据库大体结构,本文细说一下关系型数据库查询的SQL语法. 语法回顾 SELECT [ALL|DISTINCT] <目标列表达式>[ ...

  9. ASP.NET Core中间件(Middleware)实现WCF SOAP服务端解析

    ASP.NET Core中间件(Middleware)进阶学习实现SOAP 解析. 本篇将介绍实现ASP.NET Core SOAP服务端解析,而不是ASP.NET Core整个WCF host. 因 ...

  10. 背水一战 Windows 10 (28) - 控件(文本类): TextBox, PasswordBox

    [源码下载] 背水一战 Windows 10 (28) - 控件(文本类): TextBox, PasswordBox 作者:webabcd 介绍背水一战 Windows 10 之 控件(文本类) T ...