PS:本文面向的讀者是已經(jīng)接觸過AutoLayout的,如果你還未接觸過,那本文內(nèi)容可能不大容易消化,關(guān)掉本頁(yè)或點(diǎn)返回可能會(huì)更好,在信息泛濫的當(dāng)下避免攝入過量的信息也是一種智慧。
前言
從學(xué)iOS開始就接觸了AutoLayout,不過那時(shí)并不知其用法,僅會(huì)拖一拖控件,知道約束,但并未深究。直到最近開始做記賬的App時(shí),才發(fā)現(xiàn)原來AutoLayout是這么一回事。凡事皆有規(guī)律,當(dāng)你掌握了這個(gè)規(guī)律,所有東西在你眼里都是簡(jiǎn)單的,AutoLayout也不例外。
一般情況下我們知道AutoLayout會(huì)自動(dòng)計(jì)算視圖(View)的大小(Size)和位置(Position),但是前提得設(shè)置好合理的約束。這里的第一個(gè)特別重要的概念約束(constraint)就出來了!跟我們的題目有什么關(guān)系呢,其實(shí)約束就是一些等式或不等式,這些等式或不等式就代表著視圖之間的關(guān)系!
為什么說約束是一些等式或不等式?Apple的工程師設(shè)計(jì)AutoLayout的初衷就是如此。所謂的AutoLayout說白了就是通過一些等式或不等式,由AutoLayout這個(gè)機(jī)制(一堆代碼)來推斷出你視圖(views)或控件(controls)的大小和位置。你在Xcode中右鍵拉出來的每一條約束都可以被解析成代碼,然后由AutoLayout這個(gè)機(jī)制來做推斷,原理很簡(jiǎn)單,但是實(shí)現(xiàn)起來會(huì)有一堆細(xì)節(jié)要去考慮。
上圖中出現(xiàn)了一個(gè)最簡(jiǎn)單的例子,一個(gè)“Red”視圖,一個(gè)“Blue”視圖,中間有一條8個(gè)點(diǎn)(point)的約束,說的是“Red”視圖的左邊距(Leading)由“Blue”視圖的右邊距和一個(gè)常量8決定。
表達(dá)式中的item1,老外什么都喜歡叫item,基本就和中文的“個(gè)”差不多了,這個(gè)item1指的就是“Red”這個(gè)視圖。
“Red”視圖的Attribute1(屬性1)是Leading,相信有玩過AutoLayout的朋友會(huì)相當(dāng)熟悉,Top/Leading/Bottom/Trailing這四個(gè)對(duì)齊的屬性,在語(yǔ)言習(xí)慣是從左到右的情況下(希伯來文和阿拉伯語(yǔ)是從右到左),Leading其實(shí)就是Left,而Trailing就是Right,語(yǔ)言習(xí)慣是從右到左時(shí)則相反。總之這里就是邊距的意思啦,當(dāng)然還有width/height,vertical center 和horizontal center這幾個(gè),都是屬性。
Multiplier是倍數(shù),這個(gè)一般是自己設(shè)定的,比如當(dāng)你需要兩個(gè)view的寬度成倍數(shù)時(shí),就和這個(gè)Multiplier關(guān)聯(lián)起來了。
item2和Attribute2是另一個(gè)視圖的內(nèi)容,意思同item1和Attribute1。
ConstantC按字面理解就是常量啦,由圖可知兩個(gè)視圖之間的間距就是8。
上面只是舉了一個(gè)最簡(jiǎn)單的例子,每個(gè)視圖基本都有約束,而每個(gè)約束都可以像上面那樣用等式或不等式來表示,上邊距、下邊距、寬度、高度等等都可以。
再看下面一個(gè)例子
這是一個(gè)比較普遍的需求,一個(gè)label加一個(gè)textfield,用于用戶輸入姓名。
約束1表明了NameLabel的左邊距要和父視圖(SuperView)的左邊距相等
約束2表明了NameTextField的右邊距要和父視圖的右邊距相等
約束3表明了NameTextField的左邊距是NameLabel的右邊距加上一個(gè)常量
約束4表明了NameTextField的上邊距是TopLayoutGuide的下邊加上常量20.0,TopLayoutGuide是你創(chuàng)建xib或sb時(shí)就存在的。
約束5表明了NameLabel的基準(zhǔn)線要和NameTextField的基準(zhǔn)線相等,關(guān)于基準(zhǔn)線這里要說幾句,基準(zhǔn)線只適用于帶文字的視圖,也就是說你不帶文字了,基準(zhǔn)線就沒用。
圖中隱含的內(nèi)容還有很多,比如intrinsic content size(固定內(nèi)容大小),CHCR,優(yōu)先級(jí)等,不過本文想指出的是約束其實(shí)就是等式或不等式,所以這些內(nèi)容先忽略,后面有空再寫文章詳細(xì)說明。