由于AIDE中的gradle功能不完整,且bug连连,最致命的就是当涉及到分包操作时,会导致导致崩溃。
因而采用在Termux中使用gradle官方版本进行构建是一条曲线救国的路线。
注意:由于此文章仅侧重于搭建构建APK的环境,所以需要具备一定的Linux基础;由于下的官方的文件,挂个梯子再说
我这里用的是TermuxArch,其它途径安装的应该是一样的
wget https://github.com/SDRausty/TermuxArch/raw/master/setupTermuxArch.bash && bash setupTermuxArch.bash
- 为何选用Arch,首先是因为它可以访问到 /mnt/sdcard/,这样就解决了AIDE无法访问到/data/data/com.termux/的问题,这也意味着可以用AIDE开发,Termux直接到项目路径进行编译,更为方便
- 其实debian/ubuntu,centos也能够安装,但都有一定的缺陷:
- debian系发行版: 无法访问到/mnt/sdcard/;需自行编译安装glibc
- centos: 没有glibc,只能自行编译安装
- 上述几种版本安装与arch稍有差别,在结尾处会有介绍
首先安装sdkman这玩意是真的好用,使用sdkman安装gradle6.1.1
sdk install gradle 6.1.1
sdkman的详细使用方法参见官网,当然,如果你不想用sdkman,也可以直接从Gradle官网下载安装,切记不要使用sdkman安装jdk,装不上的,jdk只有手动安装
本仓库里有一分jdk8_arm65版本的,直接用就行
- 下载并解压文件
wget https://github.com/VcotyQin/TermuxWithGradle/raw/master/jdk8_arm64/jdk-8u221-linux-arm64-vfp-hflt.tar.gz && tar xzvf jdk-8u221-linux-arm64-vfp-hflt.tar.gz
- 配置环境变量(/etc/profile)
export JAVA_HOME=/root/jdk1.8.0_221 #此处为jdk路径
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib/tools.jar:${JRE_HOME}/lib/dt.jar
export PATH=${JAVA_HOME}/bin:${JAVA_HOME}/jre/bin:$PATH
记得source /etc/profile
- 创建一个android_sdk目录并进入到它
mkdir android_sdk && cd android_sdk
wget https://dl.google.com/android/repository/sdk-tools-linux-4333796.zip && unzip sdk-tools-linux-4333796.zip
(最好自行去官网复制下来链接,上述示例可能不是最新版)
- 配置环境变量,在/etc/profile添加如下内容
export ANDROID_HOME=/root/android_sdk #此处写android_sdk的路径
export PATH=$ANDROID_HOME/tools:$PATH
export PATH=$ANDROID_HOME/tools/bin:$PATH
export PATH=$ANDROID_HOME/platform-tools:$PATH
记得source一下
- 使用sdkmanager安装build-tools,platform-tools和platforms
sdkmanager "platform-tools" "build-tools;29.0.3" "platforms;android-29"
sdkmanager的详细使用方法参见官网
- 我这里编写了个shell脚本,更方便配置,目前仅支持arch系统,arm64架构。
wget https://raw.githubusercontent.com/VcotyQin/TermuxWithGradle/master/adaptTermuxARM64.sh && chmod 777 adaptTermuxARM64.sh && ./adaptTermuxARM64.sh
- 自行将本仓库中对应架构的aapt,aapt2覆盖到android_sdk/build-tools/version/下(注意对aapt,aapt2授予执行权限!!!很重要!!!!)(当然,如果你cpu的架构与原来的文件相符就不用替换)
- 安装glibc
pacman -S glibc
classpath 'com.android.tools.build:gradle:3.0.0'
中的版本号为Android Gradle插件的版本,而非Gradle的版本,官方有一个两者的对应关系。两者版本一定要对应上,否则会报错- 目前
com.android.tools.build:gradle
的版本最好低于3.1.0
,因为在3.1.0
之上启用aapt2打包资源之后会出问题 - 每一个版本的build-tools中的aapt都需替换为对应cpu架构的版本
- 不用执行
adaptTermuxARM64.sh
脚本,取而代之的是apt-get install aapt
- 不执行
pacman -S glibc
,需自行编译安装glibc:方法自行Google或百度
- 不执行
pacman -S glibc
,需自行编译安装glibc:方法自行Google或百度
手动编译安装glibc大约要用3小时
仓库中有个exampleApp可供测试,我已配置完整