电竞比分网-中国电竞赛事及体育赛事平台

分享

構(gòu)建自定義組件

 My鏡像站 2012-02-10

Android中,你的應(yīng)用程序程序與View類組件有著一種固定的聯(lián)系,例如按鈕(Button)、 文本框(TextView), 可編輯文本框(EditText), 列表框(ListView), 復(fù)選框(CheckBox), 單選框(RadioButton), 滾動(dòng)條(Gallery), 微調(diào)器(Spinner), 等等,還有一些比較先進(jìn)的有著特殊用途的View組件,例如 AutoCompleteTextView,ImageSwitcher和 TextSwitcher。除此之外,種類繁多的像 線性布局(LinearLayout), 框架布局(FrameLayout), 這樣的布局組件(Layout)也被認(rèn)為是View組件,他們是從View類派生過來的。

你的應(yīng)用程序就是這些控制組件和布局組件以某種方式結(jié)合顯示在屏幕上,一般來說這些組件對(duì)你來說基本夠用,但是你也應(yīng)該知道你是可以通過類繼承創(chuàng)建 屬于自己的組件,一般可以繼承像View、Layouts(布局組件)這樣的組件,甚至可以是一些比較高級(jí)的控制類組件。下面我們說一下為什么要繼承:

  • 你可以為實(shí)現(xiàn)某種功能創(chuàng)建一個(gè)完全自定義風(fēng)格的組件,例如用二維的圖形創(chuàng)建控制組件實(shí)現(xiàn)聲音的控制,就像電子控制一樣。
  • 你可以把幾種組件結(jié)合形成一個(gè)新的組件,你的組件可能同時(shí)包含ComboBox(一個(gè)能輸入的文本列表)和dual-pane selector control(左右兩個(gè)List窗口,你可以分配窗口每一項(xiàng)的從屬關(guān)系)等等。
  • 你可以創(chuàng)建自己的布局組件(Layout)。SDK中的布局組件已經(jīng)提供了一系列的選項(xiàng)讓你打造屬于自己的應(yīng)用程序,但是高級(jí)的開發(fā)人員會(huì)發(fā)現(xiàn)根據(jù)現(xiàn)有的Layout組件開發(fā)新的Layout組件是很有必要的,甚至是完全從底層開發(fā)新的組件。
  • 你可以覆蓋一個(gè)現(xiàn)有組件的顯示或功能。例如,改變EditText(可編輯文本)組件在屏幕上的顯示方式(可以參考Notepad的例子,里面教你如何創(chuàng)建一個(gè)下劃線的顯示頁面)。
  • 你可以捕獲像按鍵按下這樣的事件,以一些通用的方法來處理這些事件(一個(gè)游戲的例子)

基本方法(The Basic Approach )
完全自定義組件(Fully Customized Components )
定制組件的例子(Customized Component Example )
組件的混合(或者控制類的混合) (Compound Components (or Compound Controls) )
修改現(xiàn)有組件(Tweaking an Existing Component )

基本方法(The Basic Approach )
下面的一些步驟都比較概括,教你如何創(chuàng)建自己的組件:

   1. 讓你的類(Class)繼承一個(gè)現(xiàn)有的View 類或View的子類。
   2. 重載父類的一些方法:需要重載的父類方法一般以‘on’開頭,如onDraw(), onMeasure()和 onKeyDown()等等。
          * 這個(gè)在Activity 或則 ListActivity 派生中同樣適用,你需要重載一些生命周期函數(shù)和一些其他功能性的HOOK函數(shù)。
   3. 使用你的繼承類:一旦你的繼承類創(chuàng)建完成,你可以在基類能夠使用的地方使用你的繼承類,但完成功能就是你自己編寫的了。

完全自定義組件(Fully Customized Components)

完全自定義組件的方法可以創(chuàng)建一些用于顯示的圖形組件(graphical components),也許是一個(gè)像電壓表的圖形計(jì)量器,或者想卡拉OK里面顯示歌詞的小球隨著音樂滾動(dòng)。無論那種方式,你也不能單純的利用組件的結(jié)合完成,無論你怎么結(jié)合這些現(xiàn)有的組件。

幸運(yùn)的是,你可以以你自己的要求輕松地創(chuàng)建完全屬于自己的組件,你會(huì)發(fā)現(xiàn)不夠用的只是你的想象力、屏幕的尺寸和處理器的性能(記住你的應(yīng)用程序最后只會(huì)在那些性能低于桌面電腦的平臺(tái)上面運(yùn)行)。

下面簡(jiǎn)單介紹如何打造完全自定義的組件:

   1. 最為通用的VIEW類的父類毫無疑問是View類,因此,最開始你要?jiǎng)?chuàng)建一個(gè)基于此類的一個(gè)子類。
   2. 你可以寫一個(gè)構(gòu)造函數(shù)從XML文件中提取屬性和參數(shù),當(dāng)然你也可以自己定義這些屬性和參數(shù)(也許是圖形計(jì)量器的顏色和尺寸,或者是指針的寬度和幅度等等)
   3. 你可能有必要寫自己的事件監(jiān)聽器,屬性的訪問和修改函數(shù)和一些組件本身的功能上的代碼。
   4. 如果你希望組件能夠顯示什么東西,你很有可能會(huì)重載 onMeasure() 函數(shù),因而你就不得不重載 onDraw() 函數(shù)。當(dāng)兩個(gè)函數(shù)都用默認(rèn)的,那么 onDraw() 函數(shù)將不會(huì)做任何事情,并且默認(rèn)的 onMeasure() 函數(shù)自動(dòng)的設(shè)置了一個(gè)100x100 —的尺寸,這個(gè)尺寸可能并不是你想要的。
   5. 其他有必要重載的on... 系列函數(shù)都需要重新寫一次。

onDraw()和onMeasure()

onDraw()函數(shù)將會(huì)傳給你一個(gè) Canvas 對(duì)象,通過它你可以在二維圖形上做任何事情,包括其他的一些標(biāo)準(zhǔn)和通用的組件、文本的格式,任何你可以想到的東西都可以通過它實(shí)現(xiàn)。

注意: 這里不包括三維圖形如果你想使用三維的圖形,你應(yīng)該把你的父類由View改為SurfaceView類,并且用一個(gè)單獨(dú)的線程??梢詤⒖糋LSurfaceViewActivity 的例子。

onMeasure() 函數(shù)有點(diǎn)棘手,因?yàn)檫@個(gè)函數(shù)是體現(xiàn)組件和容器交互的關(guān)鍵部分,onMeasure()應(yīng)該重載,讓它能夠有效而準(zhǔn)確的表現(xiàn)它所包含部分的測(cè)量值。這就有點(diǎn) 復(fù)雜了,因?yàn)槲覀儾坏紤]父類的限制(通過onMeasure()傳過來的),同時(shí)我們應(yīng)該知道一旦測(cè)量寬度和高度出來后,就要立即調(diào)用 setMeasuredDimension() 方法。

概括的來講,執(zhí)行onMeasure()函數(shù)分為一下幾個(gè)階段:

   1. 重載的onMeasure()方法會(huì)被調(diào)用,高度和寬度參數(shù)同時(shí)也會(huì)涉及到(widthMeasureSpec 和heighMeasureSpec兩個(gè)參數(shù)都是整數(shù)類型),同時(shí)你應(yīng)該考慮你產(chǎn)品的尺寸限制。這里詳細(xì)的內(nèi)容可以參考 View.onMeasure(int, int) (這個(gè)連接內(nèi)容詳細(xì)的解釋了整個(gè)measurement操作)。
   2. 你的組件要通過onMeasure()計(jì)算得到必要的measurement長(zhǎng)度和寬度從而來顯示你的組件,它應(yīng)該與規(guī)格保持一致,盡管它可以實(shí)現(xiàn)一些規(guī) 格以外的功能(在這個(gè)例子里,父類能夠選擇做什么,包括剪切、滑動(dòng)、提交異常或者用不同的參數(shù)又一次調(diào)用onMeasure()函數(shù))。
   3. 一旦高度和寬度計(jì)算出來之后,必須調(diào)用setMeasuredDimension(int width, int height),否則就會(huì)導(dǎo)致異常。

一個(gè)自定義組件的例子(A Customized Component Example)

在 API Demos 中的CustomView提供了以一個(gè)自定義組件的例子,這個(gè)自定義組件在 LabelView 類中定義。

LabelView例子涉及到了自定義組件的方方面面:

    * 首先讓自定義組件從View類中派生出來。
    * 編寫帶參數(shù)的構(gòu)造函數(shù)(參數(shù)可以來源于XML文件)。這里面的一些處理都已經(jīng)在View父類中完成,但是任然有些Labelview使用的自定義組件特有的新的參數(shù)需要處理。
    * 一些標(biāo)準(zhǔn)的Public函數(shù),例如setText(), setTextSize(), setTextColor()
    * 重載onMeasure()方法來確定組件的尺寸(注意:在LabelView中是通過一個(gè)私有函數(shù)measureWidth()來實(shí)現(xiàn)的)
    * 重載onDraw()函數(shù)把Lable顯示在提供的canvas上。

在例子中,你可以通過custom_view_1.xml看到自定義組件LabelView的用法。在XML文件中特別要注意的是android: 和app:兩個(gè)參數(shù)的混合運(yùn)用,app:參數(shù)表示應(yīng)用程序中被認(rèn)為是LabelView組件的個(gè)體,這些也會(huì)作為資源在R類中定義。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多