Window和WindowManager(三)

原创 2016年08月30日 00:01:50

继续,我们来分析Toast的Window创建过程

  • Toast的Window创建过程
    由于Toast是系统Window,所以Toast的window创建过程相对于activity和dialog这样的应用window和子Window来说比较复杂,涉及到一些IPC的操作,这里只分析原理,不会贴系统源码。

    首先,Toast的本质也是由window来实现的,但同时Toast也具有定时取消的功能,在系统中是有handle来实现的。

    Toast内部有一些IPC的过程,一类是Toast访问NotificationManagerService,另一类是NotificationManagerService回调Toast中的TN接口。

    Toast提供了show和cancel两个方法,来用于显示和隐藏Toast,其内部都是基于IPC来实现的。

    show的时候,调用NotificationMangerService的enqueueToast方法来显示Toast。同样,cancel的时候也是通过NotificationMangerService的cancelToast来隐藏Toast。

    而NotificationManagerService运行在系统进程中,所以我们需要通过TN这个接口来进行IPC调用,两次操作的参数中均有TN参与。

    TN是一个Binder类,NotificationManagerService在处理Toast的显示与隐藏的请求的时候,同样会回调TN中的方法,但TN运行在binder线程池中,所以,就需要通过handle来将其切换回Toast请求发送的线程,来完成后续操作。

    enqueueToast方法看似是将Toast的显示请求添加到一个队列中去,但观察源码会发现,其实是一个ArrayList,集合的上限为50,这里设置上限的原因是为了防止我们通过一些循环之类的手段来一直弹出Toast,而导致其他应用的Toast根本就没有机会弹出。

    当我们的Toast请求添加到队列中之后,NotificationManagerService会通过showNextToastLocked方法来显示当前的Toast,通过调用TN对象中的callback,最终会运行在Toast发起的应用的binder线程池中,然后通过handle切换到toast的调用线程。

    Toast显示之后,NotificationManagerService会通过scheduleTimeoutLocked方法来发送一个延时消息,一段时间之后,NotificationManagerService会通过cancelToastLocked方法来隐藏Toast,并将其从队列中移除,同时如果队列中来由其他的Toast,NotificationManagerService将继续显示其他Toast。

    到这里,我们就将Toast的Window创建过程通过纯文字的描述分析完毕了,汗。。。 有些涉及到IPC过程的地方说得比较笼统,甚至为了简洁,可能会有一些错误的说法,想要深入了解的同学可以学习一下IPC相关的知识。

好,到这里,window相关的只是就算大体分析完毕了,如果有不明白的地方欢迎在博客下边留言。

还有几个遗漏的点,在这里补充一下:

应用中的每个activity都对应着一个window对象,用于描述该activity下的窗口,但不管这个应用中有多少个activity,始终只有一个windowManager,也只有一个windowManagerGlobal对象,维护着mViews,mRoots和mParams,管理所有窗口的添加,更新和删除操作。

参考资料:Android开发艺术探索

版权声明:本文为博主原创文章,转载请注明来源。

Android窗口机制(三)Window和WindowManager的创建与Activity

前两篇文章跟大家介绍了Window,PhoneWindow,DecorView他们间的联系,以及他们之间的理解。讲到Window大家肯定会想到常见的WindowManager,两者肯定是发生过关系的。...
  • HoHohong
  • HoHohong
  • 2017年01月13日 22:26
  • 511

Android 设计模式 笔记 - 深入了解WindowManager

了解一: 所有的可以显示到屏幕上的内容都是通过windowManager来操作的。包括Activity等。 了解二: WindowManager是一个非常重要的子系统。简称WMS 了解三: 和Wind...
  • u013062469
  • u013062469
  • 2016年07月05日 10:03
  • 647

关于android.view.WindowLeaked(窗体泄露)的解决方案

07-09 18:07:07.708: E/WindowManager(4843): android.view.WindowLeaked: Activity com.koridyphone.weike...
  • xuan521521
  • xuan521521
  • 2016年07月11日 09:44
  • 589

【Android】常见异常 —— android.view.WindowLeaked 分析以及解决办法

问题虽小,不过不知道还是比较麻烦的。异常信息: 10-22 10:19:38.651 12723-12723/cn.com.zte.uc E/WindowManager﹕ android.view...
  • u012386696
  • u012386696
  • 2014年10月22日 10:32
  • 3278

关于WindowManager在Android N和Android N以下表现差异的分析总结

1. 问题描述通过WindowManager往窗口里添加浮动按钮,在Android7.0时该按钮可以全局保留,直至进程被杀掉。而Android7.0以下(以Android4.4为例)浮动按钮随Acti...
  • u010429311
  • u010429311
  • 2017年07月12日 12:58
  • 329

Java反射机制在Android自动化测试框架的应用

在我们谈到这个问题时,我们不得不用的例子就是Robotium
  • u011995159
  • u011995159
  • 2014年06月08日 08:13
  • 1260

WmS详解(二)之如何理解Window和窗口的关系?基于Android7.0源码

上篇博客(WmS详解(一)之token到底是什么?基于Android7.0源码)中我们简要介绍了token的作用,这里涉及到的概念非常多,其中出现频率最高的要数Window和窗口这一对搭档了,那么我们...
  • u012702547
  • u012702547
  • 2016年11月19日 22:29
  • 2353

Android WindowManager 窗口泄漏的解决记录

12-13 17:05:58.037 27429-27429/com.android E/WindowManager: android.view.WindowLeaked: Activity com....
  • sharp36
  • sharp36
  • 2016年12月13日 17:05
  • 889

WindowManagerService和应用程序的IPC过程

1、概述大家都知道我们平时在创建应用程序的Activity时,都需要通过WindowManagerService(后面简称WMS )为启动的Activity创建对应的窗口,那今天我们就来简单的介绍一...
  • dongxianfei
  • dongxianfei
  • 2016年10月25日 19:51
  • 442

Monkey源码分析番外篇之WindowManager注入事件如何跳出进程间安全限制

在分析monkey源码的时候有些背景知识没有搞清楚,比如在看到monkey是使用windowmanager的injectKeyEvent方法注入事件的时候,心里就打了个疙瘩,这种方式不是只能在当前应用...
  • zhubaitian
  • zhubaitian
  • 2014年10月24日 15:23
  • 3075
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Window和WindowManager(三)
举报原因:
原因补充:

(最多只允许输入30个字)