• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            大龍的博客

            常用鏈接

            統計

            最新評論

            PhoneWindow,ViewRoot,Activity之間的大致關系

            android里,我們都知道activity.但是一個activity跟一個Window是一個什么關系呢?

            activity.java中,我們可以看到兩個變量,分別是:

            private Window mWindow;

            private WindowManager mWindowManager;

            這這個變量是在哪里賦值的呢?可以看到attach函數,

            mWindow = PolicyManager.makeNewWindow(this);

            跟進去看一下,可以發現返回的時候一個PhoneWindow對象,PhoneWindowWindow類的派生類。

            mWindow.setWindowManager(null, mToken, mComponent.flattenToString());

            if (mParent != null) {

            mWindow.setContainer(mParent.getWindow());

            }

            mWindowManager = mWindow.getWindowManager();

            仔細跟蹤下這段代碼中我們可以得到WindowManager對象,并且這個對象是在系統唯一的,這個對象同樣被賦值給PhoneWindow的成員變量。

            我們在新建一個activity的時候,往往喜歡用如下的代碼來定義該activityUI界面,那么這個具體的實現是怎么來實現的呢?

            public void onCreate(Bundle savedInstanceState) {

            super.onCreate(savedInstanceState);

            setContentView(R.layout.main);

            我們跟蹤setContentView就知道了。可以發現activity其實把這個操作交給了自己的mWindow來完成,通過跟蹤PhoneWindow中的setContentView函數可以得出以下知識:

            1,每一個PhoneWiondow中都有一個叫DecorView的對象,該對象是該PhoneWiondow的框架view,可以找到這么一段代碼:

            View in = mLayoutInflater.inflate(layoutResource, null);

            decor.addView(in, new ViewGroup.LayoutParams(FILL_PARENT, FILL_PARENT));

            layoutResource則是資源ID,通過往上翻代碼就可以找得到。

            2,一個PhoneWiondow中都有一個叫FrameLayout的對象mContentParent,該對象是從上述layoutResource中的布局xml中獲得的,這也將是activity中所有用戶新增加view都會被包含在這個對象當中。

            總體可以這樣大致說明:一個activity包含有一個PhoneWiondow對象,而所有的UI部件都是放在PhoneWiondow中。

            ViewRoot這個類在androidUI結構中扮演的是一個中間者的角色,連接的是PhoneWindowWindowManagerService.

            WindowManagerService中我們知道它讀取android系統里所有事件,鍵盤事件,軌跡球事件等等,它怎么分發到各個activity的呢?就是通過這個ViewRoot

            在每個PhoneWindow創建的時候,系統都會向WindowManger中的一個保存View數組增加PhoneWindowDecorView對象,WindowManger在保存好這個View對象的同時,也會新創建一個ViewRoot對象用來溝通WindowManagerService

            可以查看WindowManagerImplViewRoot中的代碼,同時ViewRoot中我們可以看到一個W類型,該類型派生自IWindow.stub可以知道這個可以被用來作遠程調用。

            res = sWindowSession.add(mWindow, mWindowAttributes,

            getHostVisibility(), mAttachInfo.mContentInsets);

            IwindowSession則是WindowManagerService中的遠程調用接口,上述代碼也表明了每創建了一個PhoneWindow,也就創建了一個ViewRoot,并將在WindowManagerService注冊。

            接下來簡單的看下KeyEvent的傳遞。在WindowManagerService

            focus.mClient.dispatchKey(event);

            這個段代碼的mClient則就是ViewRoot中的W類型,通過遠程調用,可以看看ViewRoot的處理:

            boolean handled = mView != null

            ? mView.dispatchKeyEventPreIme(event) : true;

            mView則是PhoneWindowDecorView對象,接下來怎么具體傳遞可以慢慢去跟了

            posted on 2013-01-13 12:30 大龍 閱讀(8938) 評論(0)  編輯 收藏 引用

            一级女性全黄久久生活片免费| 久久亚洲色一区二区三区| 精品国产99久久久久久麻豆| 性欧美大战久久久久久久| 免费精品国产日韩热久久| 国产偷久久久精品专区| 99国产欧美久久久精品蜜芽| 久久久久久亚洲精品不卡 | 伊人久久综在合线亚洲2019 | 国产成人综合久久久久久| 狠狠色丁香婷婷综合久久来来去| 久久精品国产一区二区三区| 久久久久青草线蕉综合超碰| 亚洲国产精品久久久久| 一本色道久久88综合日韩精品| 久久精品人人槡人妻人人玩AV| 伊人久久精品线影院| 久久99精品久久久大学生| 99久久精品国产毛片| 久久强奷乱码老熟女网站| 久久久久国产精品三级网| 久久夜色精品国产噜噜亚洲AV| 久久久WWW成人免费毛片| 久久婷婷五月综合97色| 香蕉久久久久久狠狠色| 18岁日韩内射颜射午夜久久成人| 亚洲乱码中文字幕久久孕妇黑人 | 久久精品国产男包| 久久久久香蕉视频| 91精品国产91久久久久久| 99久久成人国产精品免费| 亚洲精品白浆高清久久久久久 | 无码国产69精品久久久久网站| 久久久中文字幕日本| 国产精品无码久久综合网| 99久久这里只有精品| 人妻精品久久久久中文字幕69| 偷窥少妇久久久久久久久| 久久精品日日躁夜夜躁欧美| 色青青草原桃花久久综合| 国产精品久久久久久久app|