• <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 大龍 閱讀(8937) 評論(0)  編輯 收藏 引用

            亚洲国产一成人久久精品| 国产AⅤ精品一区二区三区久久| 久久综合视频网站| 影音先锋女人AV鲁色资源网久久| 久久久久亚洲精品日久生情| 久久婷婷五月综合色高清| 国产AV影片久久久久久| 国产成人精品综合久久久久| 色婷婷综合久久久中文字幕| 伊人久久免费视频| 熟妇人妻久久中文字幕| 99久久久久| 久久久久亚洲av无码专区喷水| 久久国产精品久久精品国产| 亚洲AⅤ优女AV综合久久久| 久久精品国产清高在天天线| 久久精品国产欧美日韩| .精品久久久麻豆国产精品| 亚洲乱码日产精品a级毛片久久 | 久久久久久久91精品免费观看| 久久亚洲精品无码AV红樱桃| 伊人久久大香线蕉精品不卡 | 亚洲а∨天堂久久精品| 国产产无码乱码精品久久鸭| 久久久久亚洲av综合波多野结衣| 久久国产精品偷99| 久久综合中文字幕| 99国产精品久久| 国产精品久久久久久久久鸭| 欧美成人免费观看久久| 欧洲国产伦久久久久久久| 精品免费久久久久国产一区| 久久久九九有精品国产| 国产精品禁18久久久夂久 | 久久婷婷五月综合97色直播| 日本道色综合久久影院| 好属妞这里只有精品久久| 91精品国产乱码久久久久久| 久久香蕉国产线看观看精品yw| 久久久久久久久久久| 久久亚洲精品人成综合网|