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

            久久精品国产色蜜蜜麻豆| 久久久SS麻豆欧美国产日韩| 麻豆亚洲AV永久无码精品久久| 久久久久久精品免费看SSS| 日产精品99久久久久久| 日韩精品国产自在久久现线拍| 天天久久狠狠色综合| 久久久久久亚洲精品影院| 99久久国产热无码精品免费| 久久久久久久99精品免费观看| 久久国产午夜精品一区二区三区| 久久久久香蕉视频| 91精品国产综合久久久久久| 日韩久久无码免费毛片软件| 久久久久人妻一区二区三区vr| 久久久久久A亚洲欧洲AV冫| 国产精品对白刺激久久久| 精品视频久久久久| 精品999久久久久久中文字幕| 日韩美女18网站久久精品| 久久香蕉一级毛片| 亚洲精品美女久久777777| 热久久最新网站获取| 久久se精品一区二区影院| 国产精品99久久久久久人| 一本色道久久88精品综合| 久久一区二区三区免费| 久久精品这里热有精品| 丰满少妇人妻久久久久久| 无码日韩人妻精品久久蜜桃| 国产精品美女久久福利网站| 久久精品国产99久久香蕉| 欧美日韩中文字幕久久伊人| 99精品久久精品| 99久久久精品免费观看国产| 久久99精品国产自在现线小黄鸭| 区久久AAA片69亚洲| 狠狠色婷婷久久一区二区| 久久无码AV中文出轨人妻| 亚洲国产精品成人AV无码久久综合影院| 久久亚洲国产欧洲精品一|