• <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就知道了??梢园l現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)  編輯 收藏 引用

            A级毛片无码久久精品免费| 精品伊人久久久| 精品久久久久久久久中文字幕| 久久综合给合久久狠狠狠97色69| 久久国产精品99国产精| 91精品国产91久久久久福利| 免费观看成人久久网免费观看| 久久综合久久综合九色| 模特私拍国产精品久久| 精品久久人妻av中文字幕| 久久精品?ⅴ无码中文字幕| 国产成人无码精品久久久性色| 国产精品久久久久久福利69堂| 婷婷久久综合| 久久综合久久久| 无码人妻久久一区二区三区免费| 久久精品人人做人人爽电影| 久久噜噜久久久精品66| 久久99国产亚洲高清观看首页| 久久久久久国产a免费观看黄色大片 | 精品久久久久久国产91| 久久婷婷五月综合色奶水99啪| 亚洲精品高清久久| 色婷婷综合久久久久中文一区二区| 久久99精品久久久久久野外| 91精品国产高清91久久久久久| 亚洲中文久久精品无码ww16| 久久夜色精品国产| aaa级精品久久久国产片| 亚洲精品乱码久久久久久中文字幕| 精品国产综合区久久久久久| 久久夜色精品国产噜噜亚洲AV| 久久精品国产亚洲AV不卡| 亚洲?V乱码久久精品蜜桃| 蜜桃麻豆www久久国产精品| 久久精品国产精品亚洲人人| 亚洲国产精品久久久久网站| 日韩一区二区久久久久久| 久久久综合九色合综国产| 久久久久无码精品国产| 国产精品久久久久9999|