Android群英傳筆記第三章(一)

Android控件架構(gòu)
View的測量與繪制
ViewGroup的測量與繪制
自定義控件的三種方式
事件的攔截機(jī)制
3.1 Android控件架構(gòu)

每個控件在界面中占據(jù)一塊矩形的區(qū)域,控件大致可以分為兩類:ViewGroup控件與View控件缸沃;ViewGroup作為父控件可以包含多個View控件妒貌,負(fù)責(zé)下層控件的測量與繪制袱贮,并傳遞交互事件

View樹結(jié)構(gòu)

Android界面的架構(gòu)圖

Android界面的架構(gòu)圖

每個Activity都包含一個Window對象悔橄,Window對象由PhoneWindow實(shí)現(xiàn)缤底;PhoneWindow將一個DecorView設(shè)置為整個應(yīng)用窗口的根View扁耐;DecorView包含了TitleView和ContentView

3.2 View的測量

Android提供了一個MeasureSpec類潦蝇,通過它來測量View款熬。MeasureSpec是一個32位的int值,高2位是測量的模式攘乒,低30位是測量的大邢团!;測量的模式分為三種:
1.EXACTLY:精確值模式(默認(rèn)模式)將控件的“l(fā)ayout_height”则酝,"layout_width"屬性指定為具體值的時候就是EXACTLY模式
2.AT_MOST:最大值模式當(dāng)寬度高度指定為“wrap_content”時殉簸,控件大小一般隨控件的子空間或內(nèi)容的變化而變化,此時控件的尺寸不能超過父控件允許的最大尺寸
3.UNSPECIFIED:不指定其大小測量模式 總結(jié):View的onMeasure()方法只支持EXACTLY模式,所以如果要讓自定義View支持"wrap_content"屬性就要重寫onMeasure()方法來指定wrap_content時的大小般卑。

源碼分析:
 @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        
    }

進(jìn)入onMeasure();方法

protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        setMeasuredDimension(getDefaultSize(getSuggestedMinimumWidth(), widthMeasureSpec),
                getDefaultSize(getSuggestedMinimumHeight(), heightMeasureSpec));
    }

我們可以看到源代碼是通過setMeasuredDimension來測量大小的

代碼示例
package com.example.view;
import android.content.Context;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.View;



/**
 * Created by 小新 on 2016/6/4.
 */
public class Myview extends View {
    public Myview(Context context) {
        super(context);
    }

    public Myview(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public Myview(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        setMeasuredDimension(widthMeasure(widthMeasureSpec),heightMeasure(heightMeasureSpec));

    }

    private int heightMeasure(int heightMeasureSpec) {
        int result = 0;
        int specMode = MeasureSpec.getMode(heightMeasureSpec);
        int specSize = MeasureSpec.getSize(heightMeasureSpec);

      if(specMode==MeasureSpec.EXACTLY){
          result=specSize;
        }else{
          result=200;
          if(specMode==MeasureSpec.AT_MOST){
              result=Math.min(result,specSize);
          }
      }
        return result;
    }
    private int widthMeasure(int widthMeasureSpec) {
        int result = 0;
        int specMode = MeasureSpec.getMode(widthMeasureSpec);
        int specSize = MeasureSpec.getSize(widthMeasureSpec);

        if(specMode==MeasureSpec.EXACTLY){
            result=specSize;
        }else{
            result=200;
            if(specMode==MeasureSpec.AT_MOST){
                result=Math.min(result,specSize);
            }
        }
        return result;
    }
}

這樣當(dāng)我們自定義寬高為"wrap_content的時候"默認(rèn)的大小是200px武鲁;不設(shè)置onMeasure()方法的時候我們使用“wrap_content”默認(rèn)的大小是充滿父控件

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蝠检,隨后出現(xiàn)的幾起案子沐鼠,更是在濱河造成了極大的恐慌,老刑警劉巖叹谁,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件饲梭,死亡現(xiàn)場離奇詭異,居然都是意外死亡本慕,警方通過查閱死者的電腦和手機(jī)排拷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锅尘,“玉大人监氢,你說我怎么就攤上這事√傥ィ” “怎么了浪腐?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長顿乒。 經(jīng)常有香客問我议街,道長,這世上最難降的妖魔是什么璧榄? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任特漩,我火速辦了婚禮,結(jié)果婚禮上骨杂,老公的妹妹穿的比我還像新娘涂身。我一直安慰自己,他們只是感情好搓蚪,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布蛤售。 她就那樣靜靜地躺著,像睡著了一般妒潭。 火紅的嫁衣襯著肌膚如雪悴能。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天雳灾,我揣著相機(jī)與錄音漠酿,去河邊找鬼。 笑死谎亩,一個胖子當(dāng)著我的面吹牛炒嘲,可吹牛的內(nèi)容都是我干的谈竿。 我是一名探鬼主播,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼摸吠,長吁一口氣:“原來是場噩夢啊……” “哼空凸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起寸痢,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤呀洲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后啼止,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體道逗,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年献烦,在試婚紗的時候發(fā)現(xiàn)自己被綠了滓窍。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡巩那,死狀恐怖吏夯,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情即横,我是刑警寧澤噪生,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站东囚,受9級特大地震影響跺嗽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜页藻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一桨嫁、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧份帐,春花似錦璃吧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽爷辙。三九已至彬坏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間膝晾,已是汗流浹背栓始。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留血当,地道東北人幻赚。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓禀忆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親落恼。 傳聞我的和親對象是個殘疾皇子箩退,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評論 2 359

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,283評論 25 707
  • 在Android開發(fā)中,自定義View可以說是從業(yè)人員從初級到中級的一個標(biāo)志性過渡佳谦,不論你是老鳥還是新人戴涝,不論你是...
    賈亦真亦賈閱讀 4,982評論 7 26
  • View的繪制和事件處理是兩個重要的主題,上一篇《圖解 Android事件分發(fā)機(jī)制》已經(jīng)把事件的分發(fā)機(jī)制講得比較詳...
    Kelin閱讀 119,665評論 100 845
  • 旁邊一個男的聲音, 打斷了我的思緒咪笑, 聽他的話可帽, 電話的另一頭應(yīng)該是他的女朋友或者妻子, 通話的中心無非就是養(yǎng)家的...
    長安府尹閱讀 594評論 0 2