从Android系统出发,分析Android控件构架

时间:2023-11-11 08:19:26

从Android系统出发,分析Android控件构架

  Android中所有的控件追溯到根源,就是View 和ViewGroup,相信这个大家都知道,但是大家也许会不太清楚它们之间的具体关系是什么,在Android的系统当中它们有充当着什么样的角色。那么下面就让我给大家捯饬捯饬。

  其实在Android当中是这样的,每个控件在Android中都是占据一个矩形的区域,而ViewGroup相当于是一个容器(大家可以这么理解)一个专门放View的一个容器,也可以放ViewGroup,并且上层的ViewGroup作为父亲控件需要管理(测量与绘制)并且传递事件给自己的孩子控件。这样的话就会形成以最上层ViewGroup为Root的一棵树,我们把这棵树就称呼为View视图树,在每一颗视图树的根部都有一个ViewParent对象,而这里的ViewParent就是这一棵树的核心控制对象,以后这颗视图树所有的事件管理交互都由ViewParent统一调度和分配,从而可以对整个视图树有更加好的管理。而我们常常使用的View.findViewById(int RsId)方法,就是在视图树上做了一个深度搜索便利查找对应元素,下图就为视图树

从Android系统出发,分析Android控件构架

  下面就说说Activity的UI界面的布局构架,

    大家都知道我们每一个Activity都有一个Window窗口对象,而Window是一个抽象类,实现是phoneWinodw来实现的,而phoneWindow先把一个DecorView设置成为整个布局的根View,而DecorView里面封装了一些常用的Window操作的常用方法,可以说是DecoeView将要显示的具体内容呈现在了PhoneWindow上面,关于上述问题,的三个概念。

  • Window:该类是一个抽象类,提供了绘制窗口的一组通用API。可以将之理解为一个载体,各种View在这个载体上显示。
  • PhoneWinodw:该类继承于Window类,是Window类的具体实现,即我们可以通过该类具体去绘制窗口。并且,该类内部包含了一个DecorView对象,该 DectorView对象是所有应用窗口(Activity界面)的根View。 简而言之,PhoneWindow类是把一个FrameLayout类即DecorView对象进行一定的包装,将它作为应用窗口的根View,并提供一 组通用的窗口操作接口。
  • DecoeView:类是PhoneWindow类的内部类。该类是一个FrameLayout的子类,并且是PhoneWindow的子类,该类就是对普通的 FrameLayout进行功能的扩展,更确切点可以说是修饰(Decor的英文全称是Decoration,即“修饰”的意思),比如说添加 TitleBar(标题栏),以及TitleBar上的滚动条等 。最重要的一点是,它是所有应用窗口的根View 。

  在显示上面,它将屏幕分成两个部分,一个是TitleBar 另一个是ContentView。而ContentView,它是一个名为content的Framelayout。

  打个不恰当比喻吧,Window类相当于一幅画(抽象概念,什么画我们未知) ,PhoneWindow为一副齐白石先生的山水画(具体概念,我们知道了是谁的、什么性质的画),DecorView则为该山水画的具体内容(有山、有水、有树,各种界面)。DecorView呈现在PhoneWindow上。

  当系统(一般是ActivityManagerService)配置好启动一个Activity的相关参数(包括Activity对象和Window对象 信息)后,就会回调Activity的onCreate()方法,在其中我们通过设置setContentView()方法类设置该Activity的显 示界面,整个调用链由此铺垫开来。setContentView()的三个构造方法调用流程本质上是一样的,我们就分析 setContentView(intresId)方法。

  Activity.setContentView(intresId) 该方法在Activity类中,该方法只是简单的回调Window对象,具体为PhoneWindow对象的setContentView()方法实现。

从Android系统出发,分析Android控件构架