Autolayout 01
Auto Layout Concepts
auto layout的基本概念是constraint(约束)。表示了你interface中的layout元素。例如,你可以创建一个约束来指定元素的宽度或者距离另一个元素的水平距离。你可以添加或者移除约束或者改变约束的属性来作用你的interface的布局。
当计算user interface运行时候的位置时,auto layout系统会在同一时间考虑所有的约束并且设置能最好满足约束的位置。
Constraint Basics
属性囊括left, right, top, bottom, leading, trailing, width, height, centerX, centerY, baseline. constant value: 以points为单位的物理大小或者offset. Relation: Auto layout支持更多。你可以使用关系和不等式比如greater-than-or-equal来说明。例如,一个view的宽度>=20。priority level。约束有优先级。默认的优先级是必须的。(NSLayoutPriorityRequired),意思是约束必须完全满足。layout系统会尽可能的满足一个可选的约束,即使不能完全实现这个约束。
优先级允许你表达有用的条件选择。例如,他们被用来表示一些控件应当总是重置大小来填充他们的contents。除非一些更加重要的出现。
约束是积累的,并且不会彼此覆盖。如果你有一个现存的约束,设置同样类型的约束不会覆盖之前的。例如,设置一个view的第二个宽度约束不会移除或者改变第一个约束宽度。你需要手动移除第一个约束。
约束可以和一些限制条件贯穿存在于view层中。在os x的mail app中,例如,默认的删除按钮在toolbar里与信息一起。
你不能设置贯穿view层的约束如果层中包含一个在layoutSubviews方法中自定义的手动设置的subviews。也不可能贯穿有bounds改变的人和views,例如scroll view。你可以认为这种情况下,有一个里面和外面的世界,但是里面的世界无法通过约束来连接到外面的世界。
Intrinsic Content Size
leaf-level views例如buttons比代码更清楚应当在什么位置。这通过intrinsic content size来告知layout系统一个view包含一些content并不是由来就被理解的并且指示这个content多大。
再比如text labels等,你应当设置元素的intrinsic size通过Editor->Size To Fit Content.这个意味着元素将grow并且shrink根据不同语言的content.
Working with Constraints in Interface Builder
添加,编辑或者移除约束的最简单方法是使用interface builder中的可视化layout tools。你可以简单得使用不同的pop-up窗口。
Adding Constraints
当添加好一个控件,但是并没有添加约束,你会发现运行时候不论device的方向时怎样的,这个控件的宽度和高度总是一样的。而且总是记住了左上角的相对位置。即便重置window的大小也无法移除或者重置元素的大小。为了让你的interface能正确的改变大小或者方向,你就需要开始添加约束了。
下面是几种添加约束的方法。
Adding Constraints with Control-Drag
添加约束最快的方法就是ctrl+drag一个view。
Adding Constraints with Align and Pin Menus
使用auto layout menu功能。
如果你只有一个元素被选择,那么约束选项需要多个元素的对应选项就无法选择。
To add a constraint from the Align or Pin menu
1. Select the checkbox next to the appropriate constraint.
To select a “Spacing to nearest neighbor” constraint, select the red constraint corresponding to the appropriate side of the element.
If you need to create a constraint related to another view that is not the nearest neighbor, click the black disclosure triangle in the value text field to display a drop-down menu of other nearby views.
Enter a corresponding constant value.
Press a button to create the constraints.
The Add Constraints button adds the new constraints to the selected elements.
The Add and Update Frames button adds the new constraints to the selected elements, and moves the elements in your interface to satisfy every constraint as well as possible.
Autolayout 01的更多相关文章
- 在StoryBoard对UICollectionViewCell 进行Autolayout是遇到的Xcode6.01的BUG
使用Sb对UICollectionViewCell 的内容进行Autolayout约束时候,发现了一个Xcode6.01的BUG,就是你对UICollectionCell约束完了之后,在模拟器上现实的 ...
- 16-UIKit(AutoLayout、Animation)
目录: 一.AutoLayout自动布局 二.动画(Animation) 回到顶部 一.AutoLayout自动布局 1.什么是AutoLayout 从ios6开始引入的新技术,是新版的自动布局技术 ...
- 非等高cell实战(01)-- 实现微博页面
非等高cell实战(01)-- 实现微博页面 学习过UITableView.AutoLayout以及MVC的相关知识,接下来通过一个微博页面实战来整合一下. 首先看一下效果图: 需求分析 此页面为非等 ...
- iOS autoLayout总结
本文转自 http://ruikq.github.io/ios/autolayout/uiscrollview/2015/01/27/iOS-autolayout%E6%80%BB%E7%BB%93. ...
- AutoLayout深入浅出五[UITableView动态高度]
本文转载至 http://grayluo.github.io//WeiFocusIo/autolayout/2015/02/01/autolayout5/ 我们经常会遇到UITableViewCell ...
- AutoLayout详解+手把手实战(转载)
首先说一下这篇博客虽然是标记为原创,但是事实并非本人亲自写出来的,知识点和例子本人花了一天各处查 找和整理最终决定写一个汇总的详解,解去各位朋友到处盲目查找的必要,因为不是转载某一个人的内容,故此不标 ...
- AutoLayout具体解释+手把手实战
首先说一下这篇博客尽管是标记为原创,可是事实并不是本人亲自写出来的.知识点和样例本人花了一天各处查找和整理终于决定写一个汇总的具体解释,解去各位朋友到处盲目查找的必要,由于不是转载某一个人的内容.故此 ...
- 01.SQLServer性能优化之----强大的文件组----分盘存储
汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 文章内容皆自己的理解,如有不足之处欢迎指正~谢谢 前天有学弟问逆天:“逆天,有没有一种方 ...
- 用Kotlin创建第一个Android项目(KAD 01)
原文标题:Create your first Android project using Kotlin (KAD 01) 作者:Antonio Leiva 时间:Nov 21, 2016 原文链接:h ...
随机推荐
- SXCPC2018 nucoj1999 占领城市
#include <iostream> #include <cstring> #include <cstdio> #include <queue> us ...
- MySQL时间字段究竟使用INT还是DateTime
今天解析DEDECMS时发现deder的MYSQL时间字段,都是用 `senddata` ) unsigned '; 随后又在网上找到这篇文章,看来如果时间字段有参与运算,用int更好,一来检索时不用 ...
- 如何在Linux下使用Rsync
如何在Linux下使用Rsync 吐槽 昨天对scp进行总结之后看到最后有说到Rsync,俗语有云:好奇心害死猫.抱着学习的态度将Rsync给找了出来,然后进行了一些简单的学习.下面介绍一些个常用的命 ...
- 记一次Entity Framework 项目的优化过程
在博客园看了不少其他大神的经验.今天也抽空贡献点自己的经验(并不是说自己也是大神..小弟还只新手程序员去年才毕业的) 好了废话不多说,直接进入主题.(具体的好坏各位看官就随便看看吧..没有什么好坏之分 ...
- Mac OS 添加 MySQL 环境变量
1.打开终端,输入: cd ~ 会进入~文件夹 2.如果 ~ 文件夹中已经存在 .bash_profile 文件,则在 : 后面追加你想要添加的路径, 3. 否则输入:touch .bash_prof ...
- OOP的三大特性------封装、继承、多态
封装 1.<1>类背后隐藏的思想是数据抽象和封装 <2>信息隐藏,隐藏对象的实现细节,不让外部直接访问到 将数据成员和成员函数一起包装到一个单元里,单元以类的形式实现 < ...
- [cocos2dx UI] CCLabelAtlas 为什么不显示最后一个字
CClabelAtlas优点,基本用法等我就不说了,这里说一个和美术配合时的一个坑!就是图片的最后一位怎么也不显示,如下图中的冒号不会显示 查了ASCII码表,这个冒号的值为58,就是在9(57)的后 ...
- Dos中查看mysql数据时 中文乱码
使用jsp页面查看数据时可以正确显示中文,但是dos窗口查看数据时中文显示乱码. 上网查了一下原因:之所以会显示乱码,就是因为MySQL客户端输出窗口显示中文时使用的字符编码不对造成的,可以使用如下的 ...
- BZOJ-3190 [JLOI2013]赛车
转成二元一次不等式组,然后半平面交. #include <cstdlib> #include <cstdio> #include <cmath> #include ...
- 洛谷P3832 [NOI2017]蚯蚓排队 【链表 + 字符串hash】
题目链接 洛谷P3832 题解 字符串哈希然后丢到hash表里边查询即可 因为\(k \le 50\),1.2操作就暴力维护一下 经复杂度分析会发现直接这样暴力维护是对的 一开始自然溢出WA了,还以为 ...