自定義View二進階

分類與流程

  1. View的繪制流程

自定義View繪制函數(shù)調(diào)用序列:


  1. 分類

  • 自定義View
    在沒有現(xiàn)成的View声搁,需要自己實現(xiàn)的時候,就使用自定義View氯庆,一般繼承自View裁良,SurfaceView或其他的View,不包含子View腾夯。
  • 自定義ViewGroup
    自定義ViewGroup一般是利用現(xiàn)有的組件根據(jù)特定的布局方式來組成新的組件颊埃,大多繼承自ViewGroup或各種Layout蔬充,包含有子View。
  1. 重要函數(shù)

  2. 構造函數(shù)
public void SloopView(Context context) {}
public void SloopView(Context context, AttributeSet attrs) {}
public void SloopView(Context context, AttributeSet attrs, int defStyleAttr) {}
public void SloopView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {}

有三個參數(shù)的構造函數(shù)中第三個參數(shù)是默認的Style班利,這里的默認的Style是指它在當前Application或Activity所用的Theme中的默認Style饥漫,且只有在明確調(diào)用的時候才會生效,以系統(tǒng)中的ImageButton為例說明:

public ImageButton(Context context, AttributeSet attrs) {
    //調(diào)用了三個參數(shù)的構造函數(shù)罗标,明確指定第三個參數(shù)
    this(context, attrs, com.android.internal.R.attr.imageButtonStyle);
}
public ImageButton(Context context, AttributeSet attrs, int defStyleAttr) {
    //此處調(diào)了四個參數(shù)的構造函數(shù)庸队,無視即可
    this(context, attrs, defStyleAttr, 0); 
}

注意:即使你在View中使用了Style這個屬性也不會調(diào)用三個參數(shù)的構造函數(shù),所調(diào)用的依舊是兩個參數(shù)的構造函數(shù)闯割。
由于三個參數(shù)的構造函數(shù)第三個參數(shù)一般不用彻消,暫不考慮,第三個參數(shù)的具體用法會在以后用到的時候詳細介紹宙拉。
排除了兩個之后宾尚,只剩下一個參數(shù)和兩個參數(shù)的構造函數(shù),他們的詳情如下:

//一般在直接New一個View的時候調(diào)用谢澈。
public void SloopView(Context context) {}
//一般在layout文件中使用的時候會調(diào)用央勒,關于它的所有屬性(包括自定義屬性)都會包含在attrs中傳遞進來。
public void SloopView(Context context, AttributeSet attrs) {}
  1. onMeasure() 測量View大小

View的大小不僅由自身所決定澳化,同時也會受到父控件的影響崔步,為了我們的控件能更好的適應各種情況,一般會自己進行測量缎谷。
從onMeasure的兩個參數(shù)中取出寬高的相關數(shù)據(jù):

@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
    int widthsize  MeasureSpec.getSize(widthMeasureSpec);      //取出寬度的確切數(shù)值
    int widthmode  MeasureSpec.getMode(widthMeasureSpec);      //取出寬度的測量模式
    
    int heightsize  MeasureSpec.getSize(heightMeasureSpec);    //取出高度的確切數(shù)值
    int heightmode  MeasureSpec.getMode(heightMeasureSpec);    //取出高度的測量模式
}

從上面可以看出 onMeasure 函數(shù)中有 widthMeasureSpec 和 heightMeasureSpec 這兩個 int 類型的參數(shù)井濒, 毫無疑問他們是和寬高相關的, 但它們其實不是寬和高列林, 而是由寬瑞你、高和各自方向上對應的測量模式來合成的一個值
測量模式一共有三種, 被定義在 Android 中的 View 類的一個內(nèi)部類View.MeasureSpec中:
|模式 |二進制數(shù)值| 描述
|---------|-----------|------
|UNSPECIFIED|00| 默認值希痴,父控件沒有給子view任何限制者甲,子View可以設置為任意大小。
|EXACTLY |01| 表示父控件已經(jīng)確切的指定了子View的大小砌创。
|AT_MOST |10| 表示子View具體大小沒有尺寸限制虏缸,但是存在上限,上限一般為父View大小嫩实。
在int類型的32位二進制位中刽辙,31-30這兩位表示測量模式,29~0這三十位表示寬和高的實際值,實際上如下:
UNSPECIFIED | 00 | 000000000000000000001111011000
注意:
如果對View的寬高進行修改了甲献,不要調(diào)用 super.onMeasure( widthMeasureSpec, heightMeasureSpec); **要調(diào)用 setMeasuredDimension( widthsize, heightsize); **

  1. onSizeChanged() 確定View大小

View的大小不僅由View本身控制宰缤,而且受父控件的影響,所以我們在確定View大小的時候最好使用系統(tǒng)提供的onSizeChanged回調(diào)函數(shù)。

@Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
    }
  1. onLaytout() 確定子View布局位置
名稱 說明 對應的函數(shù)
l View左側距父View左側的距離 getLeft();
t View頂部距父View頂部的距離 getTop();
r View右側距父View左側的距離 getRight();
b View底部距父View頂部的距離 getBottom();
  1. onDraw() 繪制
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末慨灭,一起剝皮案震驚了整個濱河市朦乏,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌氧骤,老刑警劉巖呻疹,帶你破解...
    沈念sama閱讀 210,914評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異语淘,居然都是意外死亡诲宇,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,935評論 2 383
  • 文/潘曉璐 我一進店門惶翻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姑蓝,“玉大人,你說我怎么就攤上這事吕粗》挠” “怎么了?”我有些...
    開封第一講書人閱讀 156,531評論 0 345
  • 文/不壞的土叔 我叫張陵颅筋,是天一觀的道長宙暇。 經(jīng)常有香客問我,道長议泵,這世上最難降的妖魔是什么占贫? 我笑而不...
    開封第一講書人閱讀 56,309評論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮先口,結果婚禮上型奥,老公的妹妹穿的比我還像新娘。我一直安慰自己碉京,他們只是感情好厢汹,可當我...
    茶點故事閱讀 65,381評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著谐宙,像睡著了一般烫葬。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上凡蜻,一...
    開封第一講書人閱讀 49,730評論 1 289
  • 那天搭综,我揣著相機與錄音,去河邊找鬼咽瓷。 笑死设凹,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的茅姜。 我是一名探鬼主播,決...
    沈念sama閱讀 38,882評論 3 404
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼钻洒!你這毒婦竟也來了奋姿?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,643評論 0 266
  • 序言:老撾萬榮一對情侶失蹤素标,失蹤者是張志新(化名)和其女友劉穎称诗,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體头遭,經(jīng)...
    沈念sama閱讀 44,095評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡寓免,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,448評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了计维。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片袜香。...
    茶點故事閱讀 38,566評論 1 339
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖鲫惶,靈堂內(nèi)的尸體忽然破棺而出蜈首,到底是詐尸還是另有隱情,我是刑警寧澤欠母,帶...
    沈念sama閱讀 34,253評論 4 328
  • 正文 年R本政府宣布欢策,位于F島的核電站,受9級特大地震影響赏淌,放射性物質(zhì)發(fā)生泄漏踩寇。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,829評論 3 312
  • 文/蒙蒙 一六水、第九天 我趴在偏房一處隱蔽的房頂上張望俺孙。 院中可真熱鬧,春花似錦缩擂、人聲如沸鼠冕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,715評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽懈费。三九已至,卻和暖如春博脑,著一層夾襖步出監(jiān)牢的瞬間憎乙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,945評論 1 264
  • 我被黑心中介騙來泰國打工叉趣, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留泞边,地道東北人。 一個月前我還...
    沈念sama閱讀 46,248評論 2 360
  • 正文 我出身青樓疗杉,卻偏偏與公主長得像阵谚,于是被迫代替她去往敵國和親蚕礼。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,440評論 2 348

推薦閱讀更多精彩內(nèi)容