• <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)  編輯 收藏 引用

            思思久久99热只有频精品66| 亚洲国产成人乱码精品女人久久久不卡| 亚洲国产视频久久| 久久久久亚洲AV无码观看| 色婷婷综合久久久中文字幕| 久久久久久久尹人综合网亚洲 | 囯产极品美女高潮无套久久久| 亚洲精品无码久久久久去q| 久久精品人妻一区二区三区| 亚洲国产精品久久电影欧美| 久久精品国产清自在天天线| 久久99热只有频精品8| 尹人香蕉久久99天天拍| 亚洲国产天堂久久综合网站| 无码AV波多野结衣久久| 久久精品无码免费不卡| 国内精品久久久久伊人av | 国内精品久久久久久久97牛牛 | 俺来也俺去啦久久综合网| 2021久久国自产拍精品| 久久国产乱子伦免费精品| 亚洲人AV永久一区二区三区久久| 99久久久精品| 久久久久久久久无码精品亚洲日韩 | 久久夜色精品国产网站| 久久精品国产亚洲av麻豆蜜芽| 国产日韩欧美久久| 九九久久99综合一区二区| 99精品国产在热久久无毒不卡| 99久久国产宗和精品1上映| 午夜精品久久久久9999高清| 国产精品成人无码久久久久久 | 国内精品综合久久久40p| 亚洲国产成人久久综合一区77 | 国产精品久久网| 高清免费久久午夜精品| 99久久免费国产特黄| 日本福利片国产午夜久久| 亚洲国产成人久久综合一| 久久WWW免费人成—看片| 久久丝袜精品中文字幕|