★60.自定義控件 ★02.自定義View分類與流程

0. 流程圖

1. 構(gòu)造函數(shù)

  • 繼承時要重寫部分構(gòu)造函數(shù):
//一般在直接New一個View的時候調(diào)用舆驶。
public void View(Context context) {}
//一般在layout文件中使用的時候會調(diào)用,關(guān)于它的所有屬性(包括自定義屬性)都會包含在attrs中傳遞進來缭嫡。
public void View(Context context, AttributeSet attrs) {}
public void View(Context context, AttributeSet attrs, int defStyleAttr) {}                   // 通常不用
public void View(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {}  // 通常不用

2. 使用onMeasure()測量View大小()

onMeasure()

@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);    //取出高度的測量模式
}

模式

模式 二進制數(shù)值 描述
UNSPECIFIED 00 默認值所意,父View沒有給子view任何限制,子View可以設(shè)置為任意大小拍棕。
EXACTLY 01 表示父View已經(jīng)確切的指定了子View的大小喻粹。
AT_MOST 10 表示子View具體大小沒有尺寸限制,但是存在上限笼裳,上限一般為父View大小唯卖。

注意

  • 如果在onMeasure()中對View的寬高進行修改了,不要調(diào)用 super.onMeasure(widthMeasureSpec, heightMeasureSpec) 要調(diào)用 setMeasuredDimension(widthsize, heightsize)躬柬。

3. 使用onSizeChanged()確定View大小

  • onSizeChanged()在視圖大小發(fā)生改變時調(diào)用拜轨,包括父View大小改變進而影響自定義的子View
@Override
protected void onSizeChanged(int w, int h, int oldw, int oldh) {
    super.onSizeChanged(w, h, oldw, oldh);
}

4. 使用onLayout()確定子View布局位置

  • 自定義ViewGroup時允青,需要重寫onLayout()橄碾。
  • onLayout()用于確定 子View 的位置。
  • onLayout()做的東西主要是以下幾點:
    1. 取出所有 子View 颠锉。
    2. 經(jīng)過計算得出各個 子View 位置的坐標(biāo)值法牲。
    3. 用以下函數(shù)設(shè)置 子View 位置。
child.layout(l,  t,  r,  b);
名稱 說明 對應(yīng)的函數(shù)
l View左側(cè)距父View左側(cè)的距離 getLeft()
t View頂部距父View頂部的距離 getTop()
r View右側(cè)距父View左側(cè)的距離 getRight()
b View底部距父View頂部的距離 getBottom()

5. 使用onDraw()繪制內(nèi)容

  • onDraw()是實際繪制的部分琼掠,使用的是 Canvas 繪圖拒垃。
@Override
protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
}

6. 對外提供操作方法和監(jiān)聽回調(diào)

  • 自定義完View之后,一般會對外暴露一些接口瓷蛙,用于控制View的狀態(tài)等悼瓮,或者監(jiān)聽View的變化。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末艰猬,一起剝皮案震驚了整個濱河市横堡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌冠桃,老刑警劉巖命贴,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異腊满,居然都是意外死亡套么,警方通過查閱死者的電腦和手機培己,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進店門碳蛋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人省咨,你說我怎么就攤上這事肃弟。” “怎么了零蓉?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵笤受,是天一觀的道長。 經(jīng)常有香客問我敌蜂,道長箩兽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任章喉,我火速辦了婚禮汗贫,結(jié)果婚禮上身坐,老公的妹妹穿的比我還像新娘。我一直安慰自己落包,他們只是感情好部蛇,可當(dāng)我...
    茶點故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著咐蝇,像睡著了一般涯鲁。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上有序,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天抹腿,我揣著相機與錄音,去河邊找鬼旭寿。 笑死幢踏,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的许师。 我是一名探鬼主播房蝉,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼微渠!你這毒婦竟也來了搭幻?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤逞盆,失蹤者是張志新(化名)和其女友劉穎檀蹋,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體云芦,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡俯逾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了舅逸。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片桌肴。...
    茶點故事閱讀 38,605評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖琉历,靈堂內(nèi)的尸體忽然破棺而出坠七,到底是詐尸還是另有隱情,我是刑警寧澤旗笔,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布彪置,位于F島的核電站,受9級特大地震影響蝇恶,放射性物質(zhì)發(fā)生泄漏拳魁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一撮弧、第九天 我趴在偏房一處隱蔽的房頂上張望潘懊。 院中可真熱鬧耀盗,春花似錦、人聲如沸卦尊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽岂却。三九已至忿薇,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間躏哩,已是汗流浹背署浩。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留扫尺,地道東北人筋栋。 一個月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像正驻,于是被迫代替她去往敵國和親弊攘。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,472評論 2 348

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