Android中与ViewRoot相关的一些概念
投稿于 被查看 31453 次 评论:24
Android中与ViewRoot相关的一些概念
1、View和ViewRoot
ViewRoot从名称上来理解似乎是“View树的根”,这很容易让人产生误解。因为ViewRoot并不属于View树的一份子。从源码实现上来看,ViewRoot和View对象并没有任何“血缘”关系,它既非View的子类,也非View的父类。ViewRoot可以被理解为“View树的管理者”——它有一个mView成员变量,指向的是它所管理的View树的根。
咱们看下下面的布局代码:上面的布局代码只是一份任意的布局代码,这里主要看下其结构,该布局代码的View结构可以描如下:
public WindowManager getWindowManager() {
return mWindowManager;
}
然后我们去WindowManagerImpl的代码中去查看createLocalWindowManager方法的代码,代码如下:
public WindowManagerImpl createLocalWidnowManager(Window parentWindow) {
return new WindowManagerImpl(mDisplay, parentWindow);
}从这几处代码,大家可以看到Window类中的mWindowManger引用的其实是WindowManagerImpl的实例。
4、ViewRoot和WindowManagerImpl的关系
在早期的系统版本中,WindowManagerImpl在每个进程中只有一个实例。调用它必须使用如下语句: WindowManagerImpl.getDefault();在WindowMangerImpl内部,存在3个全局变量:(下图中的源码是2.3.5中的)
它们分别用于表示View树的根节点、ViewRoot以及Window的属性。由此也可以看出,一个进程中不仅有一个ViewRoot;而Activity与ViewRoot则是一对一的关系。自Android4.3开始对此做了修改,WindowManagerImpl不再直接存储上述三个数组变量,而是由一个称为“WindowMangerGlobal”的类统一管理。 5、ViewRoot和WindowManagerService的关系 每一个ViewRootImpl内部,都有一个全局变量 static IWindowSession sWindowSession; 这个变量用于ViewRoot到WMS的连接,它是ViewRoot利用WMS的openSession()接口来创建得到的。在此基础上,ViewRoot也会通过IWindowSession.add()方法提供一个IWindow对象——从而让WMS也可以通过这个IBinder对象来与ViewRoot进行双向通信。 这里突然间冒出一个ViewRootImpl类,其实ViewRoot与ViewRootImpl的功能是一样的,只不过是Android不同版本的不同称呼。不信看下图:
既然说到这个图了,那么就在这里给大家推荐一个可以在线看Android源码的网站:http://grepcode.com/project/repository.grepcode.com/java/ext/com.google.android/android/ 其实每个Application都有一个ActivityThread主线程以及mActivities全局变量,后者记录了运行在应用程序中的所有Activity对象。一个Activity对应唯一的WindowManager以及ViewRootImpl。WindowManagerGlobal作为全局管理者,其内部的mRoots和mViews记录了Activity的ViewRootImpl和View树的顶层元素。ViewRootImpl的另一个重要角色就是负责与WMS通信。从ViewRootImpl到WMS间的通信利用的是IWindowSession,而反方向则是由IWindow来完成的。 最后补充说明一点:Activity中有一个成员变量mWindow,mWindow里面有一个成员变量mWindowManager,而mWindowManager是WindowMangerImpl类实例的引用,另外WindowMangerImpl里面包含ViewRoot(不管老版本中直接包含,还是新版本中间接包含)。 本篇博文只是为了记录我对于ViewRoot以及与ViewRoot相关的一些概念的了解。
用户评论