關于一些細節(jié)
- UILabel
[label sizeToFit]; //label的大小自動根據(jù)文字適應(僅限于自己手動創(chuàng)建的label)
autoresizing使用前的解釋:
UIViewAutoresizing是一個枚舉類型,默認是UIViewAutoresizingNone,也就是不做任何處理。
typedef NS_OPTIONS(NSUInteger, UIViewAutoresizing) {
UIViewAutoresizingNone = 0,
UIViewAutoresizingFlexibleLeftMargin = 1 << 0,
UIViewAutoresizingFlexibleWidth = 1 << 1,
UIViewAutoresizingFlexibleRightMargin = 1 << 2,
UIViewAutoresizingFlexibleTopMargin = 1 << 3,
UIViewAutoresizingFlexibleHeight = 1 << 4,
UIViewAutoresizingFlexibleBottomMargin = 1 << 5
};
各屬性解釋:
UIViewAutoresizingNone
不會隨父視圖的改變而改變UIViewAutoresizingFlexibleLeftMargin
自動調整view與父視圖左邊距,以保證右邊距不變UIViewAutoresizingFlexibleWidth
自動調整view的寬度,保證左邊距和右邊距不變UIViewAutoresizingFlexibleRightMargin
自動調整view與父視圖右邊距,以保證左邊距不變UIViewAutoresizingFlexibleTopMargin
自動調整view與父視圖上邊距,以保證下邊距不變UIViewAutoresizingFlexibleHeight
自動調整view的高度,以保證上邊距和下邊距不變UIViewAutoresizingFlexibleBottomMargin
自動調整view與父視圖的下邊距,以保證上邊距不變
在這里說明一下,如果是經(jīng)常使用Storyboard/Xib設置autoresizing,那么轉變使用代碼設置autoresizing的話,容易出現(xiàn)理解錯誤問題。比如說UIViewAutoresizingFlexibleTopMargin,也許會被誤認為是頂部距離不變,其實是底部距離不變。這個解決辦法也很簡單,只需要把使用代碼和使用Storyboard設置autoresizing,它們是相反的,只需要這樣去記就可以了。autoresizing組合使用:
也就是枚舉中的值可以使用|隔開,同時擁有多個值的功能,可以針對不同的場景作不同的變化。例如:
UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleBottomMargin
意思是:view的寬度按照父視圖的寬度比例進行縮放,距離父視圖頂部距離不變。
其它的組合類似,我這里就不一一列舉了。