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
- 組合控制元件的佈局控制元件
- iOS 【如何解決 UIView 在佈局時的"詭異"動畫效果】iOSUIView動畫
- QT佈局之控制元件空隙QT控制元件
- tkinter中frame佈局控制元件控制元件
- WPF自定義FixedColumnGrid佈局控制元件控制元件
- Flutter 佈局控制元件篇-->Row、ColumnFlutter控制元件
- Flutter 佈局控制元件篇-->Flex、ExpandedFlutter控制元件Flex
- Flutter 佈局控制元件篇-->Stack、PositionedFlutter控制元件
- Flutter 佈局控制元件篇-->Wrap、FlowFlutter控制元件
- Flutter 佈局控制元件完結篇Flutter控制元件
- Masonry佈局控制元件,自動換行控制元件
- 【android】自定義佈局控制控制元件的位置可以通過繼承FrameLayout實現Android控制元件繼承
- SAP UI5 Form 控制元件的 ColumnLayout 佈局特性UIORM控制元件
- Flutter學習指南:UI佈局和控制元件FlutterUI控制元件
- Qt 佈局中控制元件重疊、擠壓的解決方法QT控制元件
- dispaly的Grid佈局與Flex佈局Flex
- Android Material Design控制元件使用(一)——ConstraintLayout 約束佈局AndroidMaterial Design控制元件AI
- css佈局-float佈局CSS
- CSS佈局 --- 居中佈局CSS
- java:佈局方法(流佈局)Java
- qt 佈局---表單佈局QT
- 居中佈局、三欄佈局
- 佈局總結-水平居中佈局的實現
- Android中常見的佈局和佈局引數Android
- JVM虛擬機器-瞭解Java堆中物件分配、佈局和訪問的全過程JVM虛擬機Java物件
- 你有用過table佈局嗎?說說你的感受
- CSS 佈局之水平居中佈局CSS
- 彈性佈局(伸縮佈局)
- 浮動佈局 和 flex佈局Flex
- CSS佈局之三欄佈局CSS
- CSS佈局 --- 自適應佈局CSS
- CSS佈局 --- 等寬&等高佈局CSS
- Flutter第4天--基礎控制元件(下)+Flex佈局詳解Flutter控制元件Flex
- 八、android當中五大布局控制元件。其它常用佈局Android控制元件
- Flutter原理:三棵重要的樹(渲染過程、佈局約束、應用檢視的構建等)Flutter
- 自定義流式佈局:ViewGroup的測量與佈局View
- CSS經典佈局——聖盃佈局與雙飛翼佈局CSS