自定義View

http://www.gcssloop.com/customview/CustomViewProcess                                 安卓自定義View進階-分類與流程

自定義View繪製流程函數調用鏈(簡化版)

                                            自定義View繪製流程函數調用鏈

1.自定義ViewGroup
自定義ViewGroup一般是利用現有的組件根據特定的佈局方式來組成新的組件,大多繼承自ViewGroup或各種Layout,包含有子View。
    例如:應用底部導航條中的條目,一般都是上面圖標(ImageView),下面文字(TextView),那麼這兩個就可以用自定義ViewGroup組合成爲一個Veiw,提供兩個屬性分別用來設置文字和圖片,使用起來會更加方便。
2.自定義View
在沒有現成的View,需要自己實現的時候,就使用自定義View,一般繼承自View,SurfaceView或其他的View,不包含子View。
    例如:製作一個支持自動加載網絡圖片的ImageView,製作圖表等。

1.構造函數
//一般在直接New一個View的時候調用。
public void SloopView(Context context) {}
//一般在layout文件中使用的時候會調用,關於它的所有屬性(包括自定義屬性)都會包含在attrs中傳遞進來。
public void SloopView(Context context, AttributeSet attrs) {}

2.測量View大小(onMeasure)
View的大小不僅由自身所決定,同時也會受到父控件的影響,爲了我們的控件能更好的適應各種情況,一般會自己進行測量。

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    int widthsize = MeasureSpec.getSize(widthMeasureSpec);      //取出寬度的確切數值
    int widthmode = MeasureSpec.getMode(widthMeasureSpec);      //取出寬度的測量模式
    
    int heightsize = MeasureSpec.getSize(heightMeasureSpec);    //取出高度的確切數值
    int heightmode = MeasureSpec.getMode(heightMeasureSpec);    //取出高度的測量模式
}
測量模式一共有三種, 被定義在 Android 中的 View 類的一個內部類View.MeasureSpec中:
UNSPECIFIED     00     默認值,父控件沒有給子view任何限制,子View可以設置爲任意大小。
EXACTLY     01     表示父控件已經確切的指定了子View的大小。
AT_MOST     10     表示子View具體大小沒有尺寸限制,但是存在上限,上限一般爲父View大小。

如果對View的寬高進行修改了,不要調用 super.onMeasure( widthMeasureSpec, heightMeasureSpec); 要調用 setMeasuredDimension( widthsize, heightsize); 這個函數。

3.確定View大小(onSizeChanged)
View的大小不僅由View本身控制,而且受父控件的影響,所以我們在確定View大小的時候最好使用系統提供的onSizeChanged回調函數。
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
    super.onSizeChanged(w, h, oldw, oldh);
}
四個參數,分別爲 寬度,高度,上一次寬度,上一次高度。

4.確定子View佈局位置(onLayout)
在自定義ViewGroup中會用到,他調用的是子View的layout函數。onLayout一般是循環取出子View,然後經過計算得出各個子View位置的座標值,然後用以下函數設置子View位置。
child.layout(l, t, r, b);
l     View左側距父View左側的距離     getLeft();
t     View頂部距父View頂部的距離     getTop();
r     View右側距父View左側的距離     getRight();
b     View底部距父View底部的距離     getBottom();

5.繪製內容(onDraw)
onDraw是實際繪製的部分,使用的是Canvas繪圖。
@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
}


發佈了40 篇原創文章 · 獲贊 11 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章