Android开发艺术探索
第八章理解Window和WindowManager+第九章四大组件的工作过程
- 什么是Window?
答:Android中的所有视图都是通过Window呈现的,不管是Activity、Dialog还是Toast,他们的视图都是附加在Window上的,因此Window是视图的直接管理者 - Window、WindowManager和WindowManagerService三者之间的关系?
答:Window是一个抽象类,PhoneWindow是他的实现类,通过WindowManager可以创建一个Window。WindowManager的具体实现在WindowManagerService中,WindowManagerService和WindowManager的交互过程是IPC过程 - Window的类型有几种?
答:三种
应用Window:一个Activity
子Window:Dialog
系统Window:Toast和状态栏,需要申明权限才能创建 - Window是分层的,每个Window都有对应的层级,大层级可以覆盖在小层级Window上面
- WindowManager中的方法很简单,添加View,更新View和删除View
- Window的组成是什么?
答:每个Window对应一个View和一个ViewRootImpl,Window和View通过ViewRootImpl建立联系 - Window不是实际存在的,它是以VIew的形式存在的。View才是Window存在的实体。
- 简述Window的添加过程
答:Window的添加过程是通过WindowManager实现的,WindowManager是一个抽象类,实现类是WindowManagerImpl。在实现类中,addView方法是通过WindowManagerGlobal处理的,主要分为一下几步:
①检查参数是否合法,如果子Window还要进行进一步调整(参数非空性检测,子Window调整大小,如Dialog)
②创建ViewRootImpl并将View添加到链表中
③通过VIewRootImpl来更新界面并完成Window的绘制过程
View的绘制过程就是通过ViewRootImpl来完成的
④接着调用WindowSession完成Window的添加过程(绘制在应用进程,添加在系统进程),Session内部会通过WindowManagerService实现Window的添加(IPC方式) - 简述Window的删除过程
答:前面和添加过程差不多,WindowManagerImpl-->WindowManagerGlobal
①通过findViewLocker查找待删除View的索引
②调用remove方法删除
主要通过die方法完成,die方法只是发送一个请求删除的消息后就立刻返回了,如果是异步删除,发送MSG_DIE的消息,VIewRootImpl中的Handler会处理此消息并调用doDie方法,同步消息直接调用doDie方法。doDie方法中主要做四件事:
(1)垃圾回收工作,清除数据,消息等
(2)通过Session的remove方法删除Window
(3)调用View的dispatchDetachedFromWindow方法(View从Window移除时就会调用),做一些资源回收工作,中止动画、停止线程等
(4)调用WindowManagerGlobal的doRemove方法刷新数据 - 简述Window的更新过程
答:更新VIew+Window
更新View的布局参数,这一步是通过VIewRootImpl的setLayoutParams方法实现的,测量、布局、重绘三个过程;更新Window视图是通过Session实现的 - View是Android中视图的呈现方式,但是View不能单独存在,他必须依靠Window上面
- Window的创建过程
答:Activity创建时,首先通过类加载器创建Activity的实例对象,然后调用attach方法为其关联运行过程中所依赖的一系列上下文环境,在attach方法里:
系统会创建Activity所属的Window对象并为其设置回调接口(onAttachedToWindow,onDetachedFromWindow、dispatchToucheEvent等) - setContentView(Activity创建)的过程
答:setContenView是通过PhoneWindow实现的,具体实现过程如下:
(1)如果没有DecorView就创建它
(2)将View添加到DecorView的mContentParent中
(3)回调onContentChanged方法通知Activity视图发生改变
注意:这个时候DecorVIew并没有被WindowManager正式添加到Window中,因为DecorView还没有被Window识别(也就是没显示到前台),在onResume方法中才真正完成了添加和显示,才能被用户看到 - Dialog的创建过程
答:和Activity的创建过程类似,也是先创建DecorView,添加View并显示 - Toast的Window的创建过程
答:不同之处:
Toast的内部有两类IPC过程:①Toast访问NotificationManagerService ②NotificationManagerService回调Toast里的TN接口。TN类中有两个方法show和hide,因为是NMS跨进程调用,他们运行在Binder线程池中,所以在执行过程中需要切换线程(内部用Handler)实现。所以Toast无法在没有Looper的线程中弹出
问题:
- view异步删除和同步删除的区别
答:异步删除,发送msg消息,VIewRootImpl中的Handler来处理;同步删除,直接删除 - View的dispatchDetachedFromWindow方法有什么用?
答:在内部会调用onDetachedFromWindow方法,当View从Window移除时,这个方法就会调用,可以在这个方法内做一些资源回收工作,比如终止动画,停止线程等 - onAttachedToWindow,onDetachedFromWindow、dispatchToucheEvent各自的作用是什么
答:onAttachedToWindow:当VIew添加add到Window时回调
onDetachedFromWindow:当View从Window移除时回调
dispatchTouchEvent:对触摸事件进行分发,返回值根据onTouchEvent(自身拦截)或child.dispatchTouchEvent决定 - Toast和Dialog的区别
答:Dialog是子Window,必须依赖父Window
Toast是系统Window - Activity的Window创建过程有没有IPC通信?有 在attach中,但只有添加View的操作中没有