UIView控制元件佈局的過程
轉載:http://blog.csdn.net/qq_14920635/article/details/65654678
UIView控制元件佈局的過程
UIView是我們經常使用的一個基本控制元件,其中有幾個基本的佈局方法需要理清。
setNeedLayout、 layoutSubViews 、layoutIfNeed幾個方法的呼叫順序和條件。
drawRect的呼叫以及sizeToFit與sizeThatFit的關係。
setNeedLayout、 layoutSubViews 、layoutIfNeed
首先這三個方法都與子檢視的佈局有關係。
1.layoutSubViews:
新增子檢視常重寫這個方法,這個方法是用來重新佈局子檢視的,常用於對子檢視佈局,或者在其他方法中呼叫以達到重新佈局的作用。
重點注意:什麼情況下系統會自動呼叫這個方法 ?
1、init初始化不會觸發layoutSubviews
但是是用initWithFrame 進行初始化時,當rect的值不為CGRectZero時,也會觸發
2、addSubview會觸發layoutSubviews
3、設定view的Frame會觸發layoutSubviews,當然前提是frame的值設定前後發生了變化
4、滾動一個UIScrollView會觸發layoutSubviews
5、旋轉Screen會觸發父UIView上的layoutSubviews事件
6、改變一個UIView大小的時候也會觸發父UIView上的layoutSubviews事件
在蘋果的官方文件中強調:
你應該重寫這個方法僅僅當你需要改變子檢視的樣式時。
順便提一下,layoutSubViews在drawRect之前呼叫。
2.setNeedLayout:
呼叫這個方法的時候,表示設定了需要佈局子檢視的標記,但是不會馬上呼叫layoutSubViews,而是非同步呼叫(疑問?),如果需要馬上實現重新佈局,那麼應該呼叫layoutIfNeed方法。
3.layoutIfNeeds:
這個方法在設定流需要佈局標記後,會自動呼叫layoutSubViews.
所以2.3方法一般會連用。
UIView繪畫的幾個基本方法。
drawRect 、 setNeedsDisplay 、 setNeedsDisplayInRect?
這幾個方法一般與檢視繪畫有關。
1.drawRect:
呼叫這個方法會重繪檢視(包括子檢視),也可以在裡面獲得繪畫上下文,進行實時繪畫。
需要重繪新增其他的東西或者自定義繪畫,則可以通過重寫的方式實現。
該方法一般不能顯示呼叫,需要呼叫下面的方法來實現系統呼叫。
注意:
1、如果在UIView初始化時沒有設定rect大小,將直接導致drawRect不被自動呼叫。drawRect 掉用是在Controller->loadView, Controller->viewDidLoad 兩方法之後掉用的.所以不用擔心在 控制器中,這些View的drawRect就開始畫了.這樣可以在控制器中設定一些值給View(如果這些View draw的時候需要用到某些變數 值).
2、該方法在呼叫sizeToFit後被呼叫,所以可以先呼叫sizeToFit計算出size。然後系統自動呼叫drawRect:方法。
3、通過設定contentMode屬性值為UIViewContentModeRedraw。那麼將在每次設定或更改frame的時候自動呼叫drawRect:。
4、直接呼叫setNeedsDisplay,或者setNeedsDisplayInRect:觸發drawRect:,但是有個前提條件是rect不能為0。
以上1,2推薦;而3,4不提倡
drawRect方法使用注意點:
1、 若使用UIView繪圖,只能在drawRect:方法中獲取相應的contextRef並繪圖。如果在其他方法中獲取將獲取到一個invalidate 的ref並且不能用於畫圖。drawRect:方法不能手動顯示呼叫,必須通過呼叫setNeedsDisplay 或 者 setNeedsDisplayInRect,讓系統自動調該方法。
2、若使用calayer繪圖,只能在drawInContext: 中(類似魚drawRect)繪製,或者在delegate中的相應方法繪製。同樣也是呼叫setNeedDisplay等間接呼叫以上方法
3、若要實時畫圖,不能使用gestureRecognizer,只能使用touchbegan等方法來掉用setNeedsDisplay實時重新整理螢幕
2.setNeedsDisplay:
標記需要重繪,非同步呼叫drawRect方法,在下一個draw週期(1/60s)呼叫drawRect進行重繪。
3.setNeedsDisplayInRect:
標記在某個Rect範圍需要重繪。
sizeTofit、sizeThatFit的關係?
sizeToFit會自動呼叫sizeThatFits方法;
sizeToFit不應該在子類中被重寫,應該重寫sizeThatFits
sizeThatFits傳入的引數是receiver當前的size,返回一個適合的size
sizeToFit可以被手動直接呼叫
sizeToFit和sizeThatFits方法都沒有遞迴,對subviews也不負責,只負責自己
相關文章
- VC的佈局時機、所用方法以及UIView內部佈局執行順序UIView
- 組合控制元件的佈局控制元件
- Android中View的測量和佈局過程AndroidView
- jQuery EasyUI響應式佈局的實現過程jQueryUI
- iOS 【如何解決 UIView 在佈局時的"詭異"動畫效果】iOSUIView動畫
- 原始碼解析Android中View的layout佈局過程原始碼AndroidView
- QT佈局之控制元件空隙QT控制元件
- tkinter中frame佈局控制元件控制元件
- AutoFlowLayout:多功能流式佈局與網格佈局控制元件控制元件
- Flutter 佈局控制元件篇-->Row、ColumnFlutter控制元件
- Flutter 佈局控制元件篇-->Flex、ExpandedFlutter控制元件Flex
- Flutter 佈局控制元件篇-->Stack、PositionedFlutter控制元件
- Flutter 佈局控制元件篇-->Wrap、FlowFlutter控制元件
- Flutter 佈局控制元件完結篇Flutter控制元件
- Masonry佈局控制元件,自動換行控制元件
- WPF自定義FixedColumnGrid佈局控制元件控制元件
- 自定義UIView UITableViewCell等控制元件UIView控制元件
- SAP UI5 Form 控制元件的 ColumnLayout 佈局特性UIORM控制元件
- 【android】自定義佈局控制控制元件的位置可以通過繼承FrameLayout實現Android控制元件繼承
- Flutter學習指南:UI佈局和控制元件FlutterUI控制元件
- Android控制元件佈局屬性全解Android控制元件
- Android UI控制元件系列:TableLayout(表格佈局)AndroidUI控制元件
- CSS佈局 --- 居中佈局CSS
- css佈局-float佈局CSS
- dispaly的Grid佈局與Flex佈局Flex
- iOS 控制元件檢視基類之 UIViewiOS控制元件UIView
- 深入理解JVM(2) : Java堆中物件建立、佈局、訪問全過程JVMJava物件
- Android獲取dialog自定義佈局中的控制元件Android控制元件
- Qt 佈局中控制元件重疊、擠壓的解決方法QT控制元件
- 居中佈局、三欄佈局
- qt 佈局---表單佈局QT
- java:佈局方法(流佈局)Java
- flex佈局(彈性佈局)Flex
- 佈局技巧:合併佈局
- 微信小程式前置課程:flex佈局(二)微信小程式Flex
- Android UI控制元件系列:RelativeLayout(相對佈局)AndroidUI控制元件
- Android UI控制元件系列:GridView(網格佈局)AndroidUI控制元件View
- 佈局總結-水平居中佈局的實現