IOS7.0 Xcode5 AutoLayout 備忘錄


 

Xcode5 xib設置autolayout方式:

列表1:

(選擇兩個view時可設置)

左邊對齊, 

右邊對齊, 

頂部對齊, 

底部對齊, 

x軸中心對齊, 

y軸中心對齊, 

文本底標線對齊, 

 

(單選擇一個view時可設置)

對於父view的x軸中心對齊, 

對於父view的y軸中心對齊, 

 

(選擇框)

添加完約束后不進行任何操作,

在添加約束后重新擺放約束涉及到的view,

在添加約束后重新擺放所有這個容器內的view

 

確定按鈕, 選擇完上面的項目后點擊添加約束

  

上面的十字是"與最近的鄰居的約束", 填上數字, 單擊虛線變成實線就是要添加這個約束.

這里的"鄰居"是將一個包含子view的父view看做一個裝了一堆積木的盒子, 積木相對於盒子的邊框和其他的積木都作為"鄰居"

 

(定義的寬高數據約束)

寬度指定,

高度指定,

 

(定義多個view之間的寬高約束)

寬度相同,

高度相同,

 

(列表, 多個view之間的對齊約束, 等同於前一菜單的內容)

 

(列表, frame更新方式, 等同於前一菜單)

(確定按鈕, 設置約束后點擊添加)

 

(上半部分菜單的操作對象是當前選中的view, 下半部分的操作對象是選中view內的view)

刷新frame(使用當前已經設置的所有約束),

刷新約束(根據當前的約束和frame, 更新約束的constant值),

添加缺失的約束(自動添加系統認為你應該添加卻忘記添加的約束, 測試中經常搞出沖突)

重置為系統建議的約束(清理系統認為重復/沖突的約束, 測試中經常搞出問題)

清理所有約束(刪除對象上綁定的所有約束)

 

(在添加約束的時候, 刷新哪些視圖)

同級view和父view

子view

 
問題:
 
約束和約束之間會沖突, 無論是xib和xib, xib和代碼, 代碼和代碼.
約束的沖突一般在特定情況下才會報, 比如豎屏沒問題但是橫屏出現沖突, 也可能xib拖錯上來就沖突之類.
約束沖突系統自動會解決, 通常依靠的是權級, 但是由於一般情況使用無法確定某一約束應該處於什么權級, 所以很難設置正確的權級以應對沖突.
約束的沖突, 在系統自動解決時可能相同情況出現不同的處理, 導致某些不能每次都重現的問題.
約束沖突, debug連調時會出現錯誤log, 可以根據log查找解決沖突.
約束沖突, 在ios6上未見crash, 在ios7上偶發crash.
 
xib和代碼的取舍:
 
autolayout現在已經不是"用不用"的問題, 而是"怎么用"的問題, 底層框架貌似已經完全刪除了autoresizemask, 而是自動將autoresizemask轉換為auto layout 也 就是說, 這種情況下可以使用原來的autoresizemask, 但是系統還是將他們拿來當autolayout使的, 使用過程中自動轉換的constraint同樣會遭遇沖突, 沖突導致的問題更加詭異而不好處理

現在我經常碰到的就是, 比如一個控件, 它和它的父view之間使用的autolayout是用代碼指定的, 我可以確定constraint的形式, 但是在實現它的時候為了方便使用了xib處理其內部的view, xib上拖放constraint由於比較復雜而我尚未明晰, 會在某些特定的情況下出現constraint沖突, 系統自動處理沖突時會將權級較低的constraint放棄, 而由於無法明確每一條constraint應該處於什么權級, 經常會出現偶發問題(如豎屏情況下constraint之間沒有問題, 橫屏過來之后就發現某個控件內的某個label上不小心沒有刪除指定寬度的constraint, 導致變形的控件和控件內label的constraint沖突, 然后引發一系列的連鎖反應)

當然, 使用xib定義viewcontroller同樣要接觸到constraint, 而且每一個都需要管理和指定(默認constraint經常會導致沖突)

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM