IOS AutoLayout

<h2>前言</h2>

我们知道做前端开发最常打交道就是布局,为了适应不同尺寸屏幕 ,AutoLayout 重要性就不必强调了吧,这时标题党,一定会喊出Masonry。对对,无可厚非,绝对是敏捷开发必备利器。但是,但是要说不是Masonry。这时给客官估计要砸鸡蛋,甩一脸唾沫了。AutoLayout 除了Masonry 框架还有其它? 答案显而易见,肯定没有了,本小哥要说的是官方提供的NSLayoutConstraint 约束布局。 呵呵? 放着好好的Masonry 不用,干嘛要用那鬼玩意,繁琐,不说,还表意不太明确。 看过Masonry 源码的都知道,是对官方API 进行封装,才让码猿们告别又长又臭的NSLayoutConstraint 是臭,但不是我们不学习理由 起码对大多数初学者,跟着大项目估计最先见到的就是第三方的框架来说,还是有学习的必要 或许那天 碰到不准使用第三方布局框架的APP 咱也能不慌不乱

<h2>什么是NSLayoutConstraint</h2>

要学NSLayoutConstraint 就少不了要知道VFL(Visual format language) 可视化格式语法知道下大概意思就行。记住下面表达式,你就会写一半了。剩下一半,琢磨琢磨,理解下,就可迎娶高富美,走向人生巅峰了。……_

功能 表达式
水平方向 H:
垂直 V:
views [view]
superView
关系 >=,==,<=
垂直方向 V:
空间,间隙 -
优先级 @value

<h2>VFL 表达式</h2>

<pre>H:|-(50)-[view1(100)]-(20)-[view2(==view1)-|​</pre>
对初学者来说,咱一看,什么鬼,有点蒙圈。 但少侠莫急,对着上面的武功表格,包你练成乳来伸展

字面理解 水平方向距左边缘父类View 50px view1自己宽100px view2距view1 20px view2宽==view宽 (-)默认不给定值是距边界父类视图20px; 是不是感觉,也很直观

<pre>V:|-(50)-[view1(100)]-(20)-[view2(==view1)-|​</pre>
同理把上面的解释的话宽换成高

说了这么多,只会招式,不能上战场,如何出来装....

先来个简单的 就宽高约束吧
<pre>
UIView *topView =[UIView new];
topView.backgroundColor=[UIColor redColor];
UIView *bottomView =[UIView new];
bottomView.backgroundColor=[UIColor blueColor];
[self.view addSubview:topView];
[self.view addSubview:bottomView];
topView.translatesAutoresizingMaskIntoConstraints=NO;
bottomView.translatesAutoresizingMaskIntoConstraints=NO;

NSDictionary *views =NSDictionaryOfVariableBindings(topView,bottomView);
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[topVie(100)]" options:NSLayoutFormatAlignAllTop metrics:0 views:views]];
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:[topView(100)]" options:NSLayoutFormatAlignAllTop metrics:0 views:views]];</pre>
效果:


57d7fdba60b9a35896000002.png

是不是发现其实也简单,只是代码多了些而已

<pre> topView.translatesAutoresizingMaskIntoConstraints=NO; </pre>将Autoresize 可以转换AutoLayout 关闭

上面代码会发现有两个view 还有一个bottomView 呢 ??
<pre>
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[topView]-[bottomView(==topView)]" options:0 metrics:0 views:views]];

[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:|-(20)-[bottomView(==topView)]" options:0 metrics:0 views:views]];</pre>

效果:


57d7ffde60b9a35896000004.png

再来看看水平垂直居中
<pre>
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:[topView(100)]" options:NSLayoutFormatAlignAllTop metrics:0 views:views]];
[self.view addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"V:[topView(100)]" options:NSLayoutFormatAlignAllTop metrics:0 views:views]];
[self.view addConstraint:[NSLayoutConstraint constraintWithItem:topView attribute:NSLayoutAttributeCenterX relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeCenterX multiplier:1 constant:0]];
[self.view addConstraint:[NSLayoutConstraint constraintWithItem:topView attribute:NSLayoutAttributeCenterY relatedBy:NSLayoutRelationEqual toItem:self.view attribute:NSLayoutAttributeCenterY multiplier:1 constant:0]];</pre>

57d8007f60b9a35896000005.png

<h2>NSLayoutConstraint 参数用法</h2>

[NSLayoutConstraint constraintsWithVisualFormat: ① options:② metrics:③ views: ④]];

① VFL 表达式

② 约束枚举 如 NSLayoutFormatAlignAllTop 等等 views 全部顶部齐平以此类推。

③ 表达式中可以放置占位符 用来动态替换值
<pre>
[NSLayoutConstraint constraintsWithVisualFormat:@"V:[topView]-[topView(==height)]"
                         options:0
                         metrics:@{@"height":@30}
                         views:views];</pre>
④子类集合,或约束view集合

动态改变布局加速这句,就可以嗨皮的写写AutoLayout 的动画

<pre>[UIView animateWithDuration:0.3 animations:^{

  [self.view layoutIfNeeded];

}];</pre>

<h2>结尾</h2>

有了框架让我们开发无往不利,但我们也该学其根本,I can write with frame, no I can write ! 这才是王道

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容