前言
下载了AOSP源码,那我们要考虑如果开发和查看,查看的工具有Source Insight,开发和查看AndroidStudio和Eclipse,当然选择 Android Studio,官方也提供我们系统开发专用版本Android Studio for Platform ,利用强大的工具。我们如何将 AOSP 源码导入 Android Studio里面?
方式一 AndroidStudio for Platform(推荐)
因为是新出的,Android系统高版本才支持,最新系统建议使用AndroidStudio for Platform
1、准备工作
下载链接:developer.android.google.cn/studio/plat… Android-Studio for Platform,目前仅支持 Ubuntu 系统。下载好以后,使用以下命令安装:
//sudo dpkg -i /你的下载路径/asfp-2023.1.1.19-linux.deb
sudo dpkg -i /home/zhangxiaoxiao/Downloads/asfp-2023.1.1.19-linux.deb
2、Android Studio for Platform 打开系统模块
2.1 使用命令行打开:
/opt/android-studio-for-platform/bin/studio.sh
2.2 打开后点击 Import Asfp Project
2.3 导入项目模块
箭头说明
- 1、选择好我们的源码路径
- 2、填写编译源码时选择的 Product(假如不知道可以lunch看一下)
- 3、加号,来添加我们需要修改的模块,可以有多个,带Android.bp文件
- 4、勾选后可以支持 native 代码
2.4 完成后的界面
3、调试系统模块
3.1 添加源码中的 jdk 和 sdk
配置 jdk 和 sdk,点击 file -> Project Structure:
点击 Add JDK:
接着点击 + 号,添加 Android SDK:选择系统源码目录下的 out/host/linux-x86/sdk/sdk/....
接着我们需要配置项目的 sdk,点击 file -> Project Structure,点击左侧 Project、 Modules,右侧 SDK 选项选择 aosp13-android-sdk,最后点击 apply,项目开始重新索引,项目内绝大部分类方法变量均可正确跳转,至此,配置完成。
3.2 开始设置调试
我们先打开一个新的终端,打开模拟器:
source build/envsetup.sh
lunch 72
emulator
接着我们像平常一下app开发那样去打断点:
最后打勾show all processes,然后选择要断点进程:
方式二 AIDEGen
1、什么是AIDEGen
AIDEGen,大概是“Android IDE (helper) Generator”的简写,是 AOSP 源代码树中的一个工具,它允许从 Android Studio 等通常仅为非平台应用程序开发配置的 IDE 中处理系统应用程序。
AIDEGen 旨在自动化项目设置过程,以便开发人员在流行的 IDE 环境中处理 Java 项目。开发者不再需要手动配置一个 IntelliJ 项目,比如所有的项目依赖。它是一个命令行工具,提供以下功能:
- 配置 Intellij 或 Android Studio 项目文件,并解决相关的模块依赖关系。
- 为指定的子项目或构建目标启动 IDE,即 frameworks/base 或 Settings。
- 为包含构建目标的指定文件夹启动 IDE,即 cts。
- 为 Intellij 自动配置 JDK 和 Android 编码风格
2、如何使用AIDEGen
需要注意的是,AIDEGen工具是在Android10以后才被引入的一个工具,所以如果你要使用它,需要确保你下载AOSP源码并切换到Android10或更高版本的分支
2.1 首先需要在AOSP源码的根目录下执行下面的命令:
source build/envsetup.sh
lunch 72(这里具体构建哪个目标,根据你自己的情况来,你也可以使用默认的(即直接lunch回车,然后在选择)
# 如果之前已经执行就不需要,这个为了等下打开as选择sdk和jdk,注意:这个内存要足够大,不然会报内存不足
make sdk
2.2 上面一步执行成功后,即可在终端中使用AIDEGen命令了,使用下面的方法可自动编译framework模块并使用Android Studio打开项目:
aidegen framework -i s -p /home/zhangxiaoxiao/aosp/android-studio/bin -s
选项 | 多头期权 | 描述 |
---|---|---|
-d | --depth | 源引用的模块的深度。 |
-i | --ide | 启动 IDE 类型,j=IntelliJ s=Android Studio e=Eclipse c=CLion v=VS Code |
-p | --ide-path | 指定用户的 IDE 安装路径如:/home/zhangxiaoxiao/aosp/android-studio/bin。 |
-n | --no_launch | 不要启动 IDE。 |
-r | --config-reset | 重置所有 AIDEGen 的已保存配置。 |
-s | --skip-build | 跳过构建 jar 或模块。 |
-v | --verbose | 显示 DEBUG 级别的日志记录。 |
-a | --android-tree | 为 IDE 生成整个 Android 源代码树项目文件。 |
-e | --exclude-paths | 排除 IDE 中的目录。 |
-l | --language | 使用特定语言启动 IDE,j=java c=C/C++ r=Rust |
-h | --help | 显示帮助信息并退出 |
2.3 Android Studio 配置
参考方式一的3、调试系统模块
方式三 android.ipr 和 android.iml(不推荐)
1. 生成源代码工程配置文件
在导入项目之前我们要先保证代码至少成功编译了一次且并未执行make clean命令清除先前编译的内容清除,我们要先使用aosp提供的idegen工具来生成aosp项目的工程配置文件,它位于aosp根目录下的development/tools/idegen/目录
1.1 编译生成idegen.jar
source build/envsetup.sh # 每次新启动电脑都要进入目录初始化编译环境变量一次
mmm development/tools/idegen/ # 编译生成idegen.jar
1.2 生成 android.ipr 和 android.iml
./development/tools/idegen/idegen.sh
运行完毕上面的命令之后,就在根目录生成了2个文件:
android.ipr 和 android.iml
2 AOSP导入Android Studio导入代码
2.1 修改Android Studio内存配置
打开System Setings->Memory Setings ->IDE max heap size这个大小调大一点
2.2 修改android.iml文件
sourceFolder : 顾名思义就是包含的文件目录,通常我们只需要留下framework即可,我怕这边保留了framework和packages。 excludeFolder:这个标签自然就是不包含的意思,有什么目录我们不想让Android Studio去管它我们就可以使用这个目录将其排除掉。
为了排除不必要的模块,提高加载速度打开android.iml
, 找到excludeFolder
属性,我们可以看到默认有14个模块是被排除了,不会被导入的
<excludeFolder url="file://$MODULE_DIR$/./external/emma" />
<excludeFolder url="file://$MODULE_DIR$/./external/jdiff" />
<excludeFolder url="file://$MODULE_DIR$/out/eclipse" />
<excludeFolder url="file://$MODULE_DIR$/external/bluetooth" />
<excludeFolder url="file://$MODULE_DIR$/external/chromium" />
<excludeFolder url="file://$MODULE_DIR$/external/icu4c" />
<excludeFolder url="file://$MODULE_DIR$/external/webkit" />
<excludeFolder url="file://$MODULE_DIR$/frameworks/base/docs" />
<excludeFolder url="file://$MODULE_DIR$/out/host" />
<excludeFolder url="file://$MODULE_DIR$/out/target/common/docs" />
<excludeFolder url="file://$MODULE_DIR$/out/target/common/obj/JAVA_LIBRARIES/android_stubs_current_intermediates" />
<excludeFolder url="file://$MODULE_DIR$/out/target/product" />
<excludeFolder url="file://$MODULE_DIR$/prebuilt" />
<excludeFolder url="file://$MODULE_DIR$/.repo" />
但实际上,整个AOSP代码中,一般我们不会全部需要去关心,我们只需要关心framework模块,因此可以根据自己的需求多去掉一些模块,可以多加如下:
<excludeFolder url="file://$MODULE_DIR$/art" />
<excludeFolder url="file://$MODULE_DIR$/bionic" />
<excludeFolder url="file://$MODULE_DIR$/bootable" />
<excludeFolder url="file://$MODULE_DIR$/build" />
<excludeFolder url="file://$MODULE_DIR$/cts" />
<excludeFolder url="file://$MODULE_DIR$/dalvik" />
<excludeFolder url="file://$MODULE_DIR$/developers" />
<excludeFolder url="file://$MODULE_DIR$/development" />
<excludeFolder url="file://$MODULE_DIR$/device" />
<excludeFolder url="file://$MODULE_DIR$/docs" />
<excludeFolder url="file://$MODULE_DIR$/external" />
<excludeFolder url="file://$MODULE_DIR$/hardware" />
<excludeFolder url="file://$MODULE_DIR$/kernel" />
<excludeFolder url="file://$MODULE_DIR$/libcore" />
<excludeFolder url="file://$MODULE_DIR$/libnativehelper" />
<excludeFolder url="file://$MODULE_DIR$/out" />
<excludeFolder url="file://$MODULE_DIR$/pdk" />
<excludeFolder url="file://$MODULE_DIR$/platform_testing" />
<excludeFolder url="file://$MODULE_DIR$/prebuilts" />
<excludeFolder url="file://$MODULE_DIR$/sdk" />
<excludeFolder url="file://$MODULE_DIR$/system" />
<excludeFolder url="file://$MODULE_DIR$/test" />
<excludeFolder url="file://$MODULE_DIR$/toolchain" />
<excludeFolder url="file://$MODULE_DIR$/tools" />
2.3 AndroidStudio打开android.ipr
File - Open...,在项目的AOSP的根目录下找到android.ipr
3、断点调试
真机想调试系统进程需要Root权限,然后利用Magisk等软件修改:ro.debuggable = 1,可以新建模拟器时选择 非 Google Play的64位镜像,也可以得到 ro.debuggable = 1 的设备
3.1 添加调试程序
Add Configurations
3.2 添加SDK
IDE and Project Settings->Project
3.3 修改无依赖JDK
总结
至此,我们的准备工作已经全部完成,从android.ipr 和 android.iml导入AS到AIDEGen,再到最新Google官方给我们提供专用开发工具,一步一步方便我们,让我们能更方便轻松的开发Framework。