Activity、View、Window、DecorView的关系


Android中真正展示给用户的是window和view,activity在android中所的作用主要是处理一些逻辑问题,比如生命周期的管理、建立窗口等。在android中,窗口的管理还是比较重要的一块,因为他直接负责把内容展示给用户,并和用户进行交互。响应用户的输入等。 View是真正显示的矩形区域,DecorView是顶层View,也就是主View。 相互之间的关系可以理解为一个Activity包含了一个Window,这个Window其实是一个PhoneWindow,在PhoneWindow中包含了DecorView,变量名称为mDecor,mDecor有一个子View,这个子View的布局方式根据设定的主题来确定,在这个子View的xml布局中包含了一个FrameLayout元素,这个FrameLayout元素的id为content,这个content对应于PhoneWindow中的mContentParent变量,用户自定义的布局作为mContentParent的子View存在,一般情况下mContentParnet只有一个子View,如果在Activity调用addView方式实际上是给PhoneWindow中的mContentParent添加子View,由于mContentParent是一个FrameLayout,因此新的子view会覆盖通过setContentView添加的子view。仅通过setContentView添加子View类View层次与下图类似:

(上面的FrameLayout和TextView应该是标题栏,不一定有)。 
通过addView方式给Activity添加子view层次图如下所示,右下角两个LinearLayout为用户自定义的布局:

Android 的窗口管理是基于 C/S 模式的,客户端就是应用程序,服务端就是 Window Manager服务。

Activity建立一个主窗口之后,在将主窗口添加到WindowManager 时,首先要建立WindowManager的代理对象,并打开一个Session(session:会话;该session由上面函数中的第二行代码实现,实现 IWindowSession AIDL 接口),并维持该会话(Activity将通过该会话与WindowManager 建立联系,这个Session 是C/S 体系的基础)。Client通过这个Session将window加入到WindowManager中。

public static IWindowSession getWindowSession(Looper mainLooper) { InputMethodManager imm = InputMethodManager.getInstance(mainLooper); //获取回话Session,ViewRoot和Window manager通信, return sWindowSession = IWindowManager.Stub.asInterface(ServiceManager.getService("window")) .openSession(imm.getClient(), imm.getInputContext()); } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

一个完整的窗口概念包含了 View,ViewRoot,Window Manager Service,Window,Decor View,IWindow,ISession,WindowState。他们之间的关系如下:

Client 端的 Activity 通过 IWindowSession 会话与Window Manager Service 建立对话,而 Window Manager Service 通过 IWindow 接口访问 Client,将消息传递到Client 端,在通过消息分发渠道,将消息传递到具体的消息处理函数。(用户输入等操作最先是到窗口管理服务,由窗口管理服务发给活动窗口,再一步步传递到焦点)。

通过IWindowSession机制就可以保证Activity和Window manager保持联系,通过IWindow可以将window manager收集到的消息分发出去。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM