【问题分析】关于SF侧Launcher层级的分析【Android15】
创始人
2024-09-26 14:48:37
0

在这里插入图片描述

一般来说,SF侧的Layer层级和WMS侧WindowContainer侧的层级是一一对应的,但是对Launcher来说,则略有不同,这点之前我在打印SF信息的时候,也有注意过,但是没有去仔细思考过为什么会这样,直到这次分析问题的时候踩了一坑,才发现有必要梳理一下这块逻辑,并做个记录。

1 问题描述

进入超级省电模式(也是一个Launcher),然后随便打开一个App,如Message,然后在Message界面上划,发现无法返回到Home。

2 问题分析

2.1 分析1

最初我分析的方向是错误的,刚拿到这个问题的时候,我复现了一下,先看上层WMS处WindowContainer的信息:

在这里插入图片描述

没问题,Home类型的Task已经在TaskDisplayArea的top了。

再看SF:

在这里插入图片描述

Message仍然是可见的。

因此我就直接认为是SF侧没有把Launcher对应的Task移动到TaskDisplayArea的top,比如Transaction.setLayer这个方法没有被调用之类的,但是继续打印log后才发现,正常情况下也没有为Home类型的Task设置layer的操作,这个分析方向是错的。

2.2 对Home类型Task的层级的特殊处理

正常情况下,当我从任意一个App回到Home后,再看此时winscope的信息:

在这里插入图片描述

发现虽然Launcher是可见的,但是它在SF侧仍然是出于TaskDisplayArea的bottom的,而在WMS侧,它在WindowContainer层级结构中是处于TaskDisplayArea的top的。

画个示意图,按照层级高的在上的形式。

WMS侧的情况为:

在这里插入图片描述

SF侧的情况为:

在这里插入图片描述

WMS侧的情况是符合直觉的,但是SF侧的确是Launcher的Task在底部,为什么会这样呢?

直接看TaskDisplayArea调整Task的层级地方,在TaskDisplayArea.assignRootTaskOrdering:

在这里插入图片描述

其实逻辑很清楚了,首先定义一个局部变量layer,初始化为0,然后每次都是先调用TaskDisplayArea.adjustRootTaskLayer来设置Home类型的Task的层级,所以Home类型的Task在SF侧TaskDisplayArea中就是一直处于bottom的。

最终TaskDisplayArea.adjustRootTaskLayer会调用WindowContainer.assignLayer,这里会调用Transaction.setLayer来完成最终的Layer设置,调用堆栈为:

在这里插入图片描述

可以看到调用的时机是在动画就绪的时候,Transition.onTransactionReady。

最后说一下,想要让Home类型的Task能够在屏幕上被看见,那么就只能在适当的时机隐藏位于Home类型Task之上的其它Task,如果这两个Task都是可见的,那么普通的App Task遮挡住Home类型的Task。

当前问题就是这个原因,继续分析。

2.3 分析2

经过以上分析,可知我们分析的重点不是在于SurfaceControl的层级设置,而是在于SurfaceControl的可见性(show和hide)设置。

先来回顾一下Transition中和可见性相关的重要节点,以从Message回到Launcher为例:

1)、启动Launcher,Launcher相关ActivityRecord变为可见。

2)、在动画就绪,Transition.onTransactionReady的时候,需要将Launcher的相关Layer设置为可见。

3)、然后播放动画,此时参与动画的Message和Launcher的相关Layer都应该是可见的。

4)、动画结束,Message相关的ActivityRecord变为不可见,那么它的Task也会被认为是不可见,进而调用Transaction.hide来隐藏它的SurfaceControl,堆栈为:

在这里插入图片描述

因此我们应该关注动画结束后,Message对应的Task没有去隐藏。

之后就定位到了问题原因,发现整个过程中没有“Finish transition”相关的log打印,说明动画流程没有走完,那么自然也不会将Message对应的Task隐藏。

再结合Launcher那边说它们是通过startRecentsTransition等接口来启动相关Home Activity的,因此很大概率是本次启动是瞬态启动。

瞬态启动一个重要的特点就是,从一个界面进入Recents,并且离开Recents后,一个完成的Transition才算完成,如果只是进入Recents,那么Transition只走到了Transition.onTransactionReady,只有从Recents界面离开(选择Recents界面的一个应用进入,或者点击Recents界面的空白区域回到Home),动画才会开始播放,并且最终走到finishTransition阶段,也就是说需要Launcher那边的动画开始播放并且播放完成后Transition才会结束,因此需要Launcher那边继续排查。

相关内容

热门资讯

怎么解锁安卓系统解,轻松掌握解... 你是不是也和我一样,对安卓系统的解锁充满了好奇?想象一台全新的安卓手机,封印在系统锁的神秘之中,等待...
安卓系统相册照片排序,照片排序... 手机里的照片就像时间的碎片,记录着我们生活的点点滴滴。但是,你有没有发现,有时候打开相册,那些照片就...
安卓8.0比7.0系统,从7.... 你有没有发现,手机更新换代的速度简直就像坐上了火箭呢?这不,安卓系统又来了一次大升级,从安卓7.0一...
纯净版安卓系统12,探索全新系... 亲爱的读者们,你是否厌倦了那些被厂商深度定制的安卓系统?想要回归安卓的纯净本质?那就跟着我一起探索纯...
安卓系统点电脑截图,安卓电脑截... 你有没有想过,在安卓系统上用电脑截图竟然也能这么方便?没错,就是那种平时我们用来保存聊天记录、分享游...
安卓系统如何调出亮度,安卓系统... 手机屏幕亮度不够,看不清内容,是不是有点头疼呢?别急,今天就来教你怎么轻松调出安卓系统的亮度,让你的...
安卓子系统无法安装,安卓子系统... 最近是不是你也遇到了安卓子系统无法安装的烦恼?别急,让我来给你详细解析一下这个问题,让你轻松解决它!...
如何装谷歌 安卓系统,一键解锁... 你有没有想过,让你的安卓手机瞬间变身成为谷歌的忠实粉丝呢?想象那些只属于谷歌的独家应用和功能,是不是...
安卓能用斑马系统吗,探索跨界融... 你有没有想过,你的安卓手机能不能用斑马系统呢?这可是个让人好奇的问题,毕竟斑马系统在智能汽车领域可是...
originosocean切换... 你知道吗?最近有个大新闻在科技圈里炸开了锅,那就是OriginOS系统要切换回安卓系统了!这可真是让...
安卓系统后期卡顿,揭秘原因与优... 手机用久了是不是感觉越来越慢,打开个应用都要等半天?这不,最近好多朋友都跟我抱怨说,他们的安卓手机怎...
魅蓝系统是不是安卓系统,深度解... 你有没有听说过魅蓝系统?是不是好奇它是不是安卓系统呢?别急,今天就来给你揭秘这个谜团,让你对魅蓝系统...
安卓系统与ios系统差距在哪,... 你有没有发现,现在手机市场上安卓系统和iOS系统就像是一对“欢喜冤家”,各有各的拥趸,各有各的特色。...
安卓手机清理系统文件,安卓手机... 亲爱的手机控们,你是不是也和我一样,每天对着手机屏幕,却总觉得内存不够用呢?别急,今天就来和你聊聊如...
安卓系统滚动条,功能与设计解析 你有没有发现,在使用安卓手机的时候,有时候屏幕下方会出现一条细细的滚动条呢?这可不是什么小问题,它可...
安卓权限系统的含义,保障安全与... 你知道吗?在智能手机的世界里,有一个超级重要的东西叫做“安卓权限系统”。它就像是一个超级管家,负责管...
华为平板安卓系统9,畅享智能新... 亲爱的读者们,你是否曾想过,一款平板电脑,如何能让你在工作和娱乐中游刃有余?今天,就让我带你走进华为...
鸿蒙系统与安卓关系,探索与安卓... 你知道吗?最近科技圈里有个大新闻,那就是鸿蒙系统与安卓的关系。这俩家伙,一个是华为的亲儿子,一个是全...
最好安卓系统手机排名,性能与创... 你有没有想过,在这个科技飞速发展的时代,拥有一部性能卓越的安卓手机是多么重要的事情呢?想象每天陪伴你...
小米电视 进入安卓系统,畅享安... 亲爱的读者们,你是否也和我一样,对科技产品的新鲜事充满好奇?今天,我要和你聊聊一个让人眼前一亮的话题...