AutoLayout

AutoLayout

autolayout的概念

Autolayout是一種“自動(dòng)布局”技術(shù)混移,專門用來布局UI界面的 Autolayout自iOS 6開始引入,由于Xcode 4的不給力埃仪,當(dāng)時(shí)并沒有得到很大推廣 自iOS 7(Xcode 5)開始,Autolayout的開發(fā)效率得到很大的提升 蘋果官方也推薦開發(fā)者盡量使用Autolayout來布局UI界面 Autolayout能很輕松地解決屏幕適配的問題


autolayout的錯(cuò)誤和警告

警告

控件的frame不匹配所添加的約束, 比如 比如約束控件的寬度為100, 而控件現(xiàn)在的寬度是110

錯(cuò)誤

缺乏必要的約束, 比如只約束了寬度和高度, 沒有約束具體的位置

兩個(gè)約束沖突, 比如,1個(gè)約束控件的寬度為100,1個(gè)約束控件的寬度為110

代碼實(shí)現(xiàn)autolayout

代碼實(shí)現(xiàn)Autolayout的步驟

利用NSLayoutConstraint類創(chuàng)建具體的約束對(duì)象 添加約束對(duì)象到相應(yīng)的view上

-(void)addConstraint:(NSLayoutConstraint *)constraint;-(void)addConstraints:(NSArray *)constraints;

代碼實(shí)現(xiàn)Autolayout的注意點(diǎn)

要先禁止autoresizing功能陕赃,設(shè)置view的下面屬性為NO

view.translatesAutoresizingMaskIntoConstraints = NO;

添加約束之前卵蛉,一定要保證相關(guān)控件都已經(jīng)在各自的父控件上 不用再給view設(shè)置frame

一個(gè)NSLayoutConstraint對(duì)象就代表一個(gè)約束


創(chuàng)建約束對(duì)象的常用方法

+(id)constraintWithItem:(id)view1 attribute:(NSLayoutAttribute)attr1 relatedBy:(NSLayoutRelation)relation toItem:(id)view2 attribute:(NSLayoutAttribute)attr2 multiplier:(CGFloat)multiplier constant:(CGFloat)c;view1 :要約束的控件attr1 :約束的類型(做怎樣的約束)relation :與參照控件之間的關(guān)系view2 :參照的控件attr2 :約束的類型(做怎樣的約束)multiplier :乘數(shù)c :常量

自動(dòng)布局的核心計(jì)算公式 obj1.property1 =(obj2.property2 * multiplier)+ constant value

在創(chuàng)建約束之后,需要將其添加到作用的view上

在添加時(shí)要注意目標(biāo)view需要遵循以下規(guī)則:

1)對(duì)于兩個(gè)同層級(jí)view之間的約束關(guān)系么库,添加到它們的父view上

2)對(duì)于兩個(gè)不同層級(jí)view之間的約束關(guān)系傻丝,添加到他們最近的共同父view上

3)對(duì)于有層次關(guān)系的兩個(gè)view之間的約束關(guān)系,添加到層次較高的父view上


VFL

VFL全稱是Visual Format Language诉儒,翻譯過來是“可視化格式語言”

VFL是蘋果公司為了簡化Autolayout的編碼而推出的抽象語言

VFL示例

-H:[cancelButton(72)]-12-[acceptButton(50)]canelButton寬72葡缰,acceptButton寬50,它們之間間距12H:[wideView(>=60@700)]wideView寬度大于等于60point,該約束條件優(yōu)先級(jí)為700(優(yōu)先級(jí)最大值為1000泛释,優(yōu)先級(jí)越高的約束越先被滿足)

V:[redBox][yellowBox(==redBox)]豎直方向上滤愕,先有一個(gè)redBox,其下方緊接一個(gè)高度等于redBox高度的yellowBoxH:|-10-[Find]-[FindNext]-[FindField(>=20)]-|水平方向上胁澳,F(xiàn)ind距離父view左邊緣默認(rèn)間隔寬度该互,之后是FindNext距離Find間隔默認(rèn)寬度;再之后是寬度不小于20的FindField韭畸,它和FindNext以及父view右邊緣的間距都是默認(rèn)寬度宇智。(豎線“|” 表示superview的邊緣)

VFL使用

使用VFL來創(chuàng)建約束數(shù)組+ (NSArray*)constraintsWithVisualFormat:(NSString*)format options:(NSLayoutFormatOptions)opts metrics:(NSDictionary*)metrics views:(NSDictionary*)views;format :VFL語句opts :約束類型metrics :VFL語句中用到的具體數(shù)值views :VFL語句中用到的控件創(chuàng)建一個(gè)字典(內(nèi)部包含VFL語句中用到的控件)的快捷宏定義NSDictionaryOfVariableBindings(...)


第三方框架Masonry

一般在調(diào)用方法前有Mas_的前綴,要省略必須在導(dǎo)入頭文件前使用以下的宏定義

#define MAS_SHORTHAND

#define MAS_SHORTHAND_GLOBALS

示例

[iconImageView makeConstraints:^(MASConstraintMaker *make) {? ? ? ? ? make.left.top.equalTo(self.contentView).offset(margin);? ? ? make.bottom.equalTo(self.contentView).offset(-margin);? ? ? make.width.equalTo(80);? }];

示例

第一條約束表示控件距離contentView上和左的間距為margin

第二條表示距離底部間距為margin

第三條表示寬度為80;

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市胰丁,隨后出現(xiàn)的幾起案子随橘,更是在濱河造成了極大的恐慌,老刑警劉巖锦庸,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件机蔗,死亡現(xiàn)場離奇詭異,居然都是意外死亡甘萧,警方通過查閱死者的電腦和手機(jī)萝嘁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扬卷,“玉大人牙言,你說我怎么就攤上這事」值茫” “怎么了咱枉?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長徒恋。 經(jīng)常有香客問我蚕断,道長,這世上最難降的妖魔是什么入挣? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任亿乳,我火速辦了婚禮,結(jié)果婚禮上径筏,老公的妹妹穿的比我還像新娘风皿。我一直安慰自己,他們只是感情好匠璧,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著咸这,像睡著了一般夷恍。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天酿雪,我揣著相機(jī)與錄音遏暴,去河邊找鬼。 笑死指黎,一個(gè)胖子當(dāng)著我的面吹牛朋凉,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播醋安,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼杂彭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了吓揪?” 一聲冷哼從身側(cè)響起亲怠,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎柠辞,沒想到半個(gè)月后团秽,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡叭首,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年习勤,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片焙格。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡图毕,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出间螟,到底是詐尸還是另有隱情吴旋,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布厢破,位于F島的核電站荣瑟,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏摩泪。R本人自食惡果不足惜笆焰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望见坑。 院中可真熱鬧嚷掠,春花似錦、人聲如沸荞驴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽熊楼。三九已至霹娄,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背犬耻。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國打工踩晶, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人枕磁。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓渡蜻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親计济。 傳聞我的和親對(duì)象是個(gè)殘疾皇子茸苇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容