玩转Android Framework:Launcher启动

本文将介绍有关Android Launcher启动相关的一些知识。

系统版本: Ubuntu 22.04 lts

AOSP分支: android-14.0.0_r28

在阅读本篇建议先阅读:

System Server

juejin.cn/post/734508...

什么是Launcher

Launcher的概念,应该做应用层开发的都不会陌生,它可以说对用户来讲最重要的一个东西了,就好像Windows的桌面一样,也是我们其它应用主要的入口。

Launcher本质上来讲,也只是我们的一个Android应用,既然是应用,就肯定要被启动,那么问题来了,谁启动了Launcher?

谁启动了Launcher

我想这个问题肯定立刻就有人抢答了,要么说是System Server,要么说是ActivityManagerService,那么真的是这样吗? 就让我们接下来一探究竟。

启动源码分析

打开/frameworks/base/services/java/com/android/server/SystemServer.java,如果了解了SystemServer.java这个类的话,就应该知道它的主要工作就是启动一系列的重要Service,找到startOtherServices方法,拉到最后,可以找到如下代码:

可以看到,在这里SystemServer调用了ActivityManagerServicesystemReady方法,进入此方法,其它的先不管,找到这段代码:

可以看到这里调用了mAtmInternal.startHomeOnAllDisplays,这个mAtmInternal其实是一个ActvityTaskManagerService实例,我们进入ActvityTaskManagerServicestartHomeOnAllDisplays这个方法,然后可以看到它依次调用了:

最终,我们进入RootWindowContainerstartHomeOnTaskDisplayArea方法:

可以看到,这个方法的主要内容就是构造了一个homeIntent,最后调用ActivityStartControllerstartHomeActivity方法,将Intent发送了出去:

我们再看里面的getHomeIntent方法,可以看到确实加了Home的Category:

接下来,应该就是启动Luancher了吧。

Log分析

好,我们接下来验证一下。

首先打开我们的模拟器,等待它进入到Launcher之后,接着进入adb shell,输入logcat | grep "ActivityTaskManager: START",然后可以看到如下的日志:

log 复制代码
03-13 17:51:41.529   509   509 I ActivityTaskManager: START u0 {act=android.intent.action.MAIN cat=[android.intent.category.HOME] flg=0x10000100 cmp=com.android.settings/.FallbackHome (has extras)} with LAUNCH_MULTIPLE from uid 0 (BAL_ALLOW_ALLOWLISTED_UID) result code=0
03-13 17:51:35.896   509   937 I ActivityTaskManager: START u0 {act=android.intent.action.MAIN cat=[android.intent.category.HOME] flg=0x10000100 cmp=com.android.launcher3/.uioverrides.QuickstepLauncher (has extras)} with LAUNCH_SINGLE_TASK from uid 0 (BAL_ALLOW_ALLOWLISTED_UID) result code=0

可以看到,我们启动的第一个Activity,并不是Luancher而是com.android.settings.FallbackHome,那么问题就来了,FallbackHome是什么?

FallbackHome是什么

我们打开/packages/apps/Settings/src/com/android/settings/FallbackHome.java,先看看它的布局文件:

好像也没什么特别内容,再看看它的代码,尤其注意以下三块:

可以看到多处在尝试调用这个maybeFinish,那么我们再看下这个方法:

这里的核心逻辑,其实就是调用isUserUnlocked这个方法,然后只要返回true,那么就再发送一个Home Intent,从上面的Activity启动log我们可以得知,这里的Home Intent,就会被Launcher拦截了。

那么isUserUnlocked到底代表什么? 其实这代表着设备的解密,这也是为什么我们需要FallbackHome的原因。

为什么需要FallbackHome

如果想要知道这个,首先我们就要了解什么是文件级加密直接启动,这里是官方文档:

文件级加密

source.android.com/docs/securi...
直接启动

developer.android.com/privacy-and...

简单来说,在Android 7以后,Android开始支持文件级加密,Android 10以后,更是开始强制使用文件级加密,文件级加密将存储分成了两部分,凭据加密部分和设备加密部分,以下是两者区别:

对于我们的设备来讲,刚开始开机的时候,系统属于未解密状态,因为Launcher可能与其它的很多应用会产生数据的交互,需要读取凭据加密存储空间,所以默认情况下无法支持直接启动,那么我们就需要一个loading页面作为中间页,让他来显示等待页面,等待解密完成后,由它来启动Launcher。

我们可以打开/packages/apps/Settings/AndroidManifest.xml,可以看到整个FallBackHome所属于的整个Setting应用都增加了对直接启动模式的支持:

至此,我们就完成了对Launcher启动的整个源码分析。

相关推荐
xvch4 小时前
Kotlin 2.1.0 入门教程(八)
android·kotlin
limingade5 小时前
手机app如何跳过无障碍权限实现弹框自动点击-ADB连接专题
android·adb·智能手机·蓝牙电话·手机提取通话声音
limingade5 小时前
如何跨互联网adb连接到远程手机-蓝牙电话集中维护
android·arm开发·adb·智能手机·信息与通信·蓝牙电话
dal118网工任子仪7 小时前
79,【3】BUUCTF WEB [GXYCTF2019]BabysqliV3.0
android·前端
东京老树根7 小时前
Android - 通过Logcat Manager简单获取Android手机的Log
android·智能手机
天才奇男子7 小时前
数据库用户管理
android·数据库·adb
aerror15 小时前
Macos下交叉编译安卓的paq8px压缩算法
android·macos
zhangphil16 小时前
Android BitmapShader简洁实现马赛克,Kotlin(二)
android·kotlin
我的青春不太冷16 小时前
在Android中通过JNI实现Java与C++的交互:Hello World示例
android·java·开发语言·c++·经验分享·程序人生
ansondroider16 小时前
Android GLSurfaceView 覆盖其它控件问题 (RK平台)
android·overlay·glsurfaceview·surfaceview