本文的内容属 在linux服务器上 搭建 Gluon 编译 android-apk 环境
这一篇文章直接跟着官网操作一次性成功
sudo yum update
sudo yum install gcc ld -y
sudo yum install pkgconfig gtk3-devel libXtst-devel -y
如果遇到连接超时的问题,就更新一下yum源,我切换的是阿里云的yum源,centos8的系统参考这篇文章
下面是我提炼过的内容
# 命令备份之前的repo文件
sudo rename '.repo' '.repo.bak' /etc/yum.repos.d/*.repo
# 运行以下命令下载最新的repo文件
# 注意 我们不是阿里云的ECS实例
# 需要将后面所有命令中的源地址http://mirrors.cloud.aliyuncs.com替换为http://mirrors.aliyun.com
sudo wget http://mirrors.cloud.aliyuncs.com/repo/Centos-vault-8.5.2111.repo -O /etc/yum.repos.d/Centos-vault-8.5.2111.repo
sudo wget http://mirrors.cloud.aliyuncs.com/repo/epel-archive-8.repo -O /etc/yum.repos.d/epel-archive-8.repo
# 替换repo文件中的链接
sudo sed -i 's/http:\/\/mirrors.cloud.aliyuncs.com/url_tmp/g' /etc/yum.repos.d/Centos-vault-8.5.2111.repo && sudo sed -i 's/http:\/\/mirrors.aliyun.com/http:\/\/mirrors.cloud.aliyuncs.com/g' /etc/yum.repos.d/Centos-vault-8.5.2111.repo && sudo sed -i 's/url_tmp/http:\/\/mirrors.aliyun.com/g' /etc/yum.repos.d/Centos-vault-8.5.2111.repo
sudo sed -i 's/http:\/\/mirrors.aliyun.com/http:\/\/mirrors.cloud.aliyuncs.com/g' /etc/yum.repos.d/epel-archive-8.repo
# 重新创建缓存
sudo yum clean all && yum makecache
vi ~/.bashrc # 编辑到用户环境变量中
export HISTSIZE=10000 # 设置最大条目数为 1000
export HISTFILESIZE=20000 # 设置最后一次会话保存的历史条目数为 2000
export HISTCONTROL=ignoreboth # 忽略命令参数的重复和还未执行的命令
export PATH=$PATH:~/bin
source ~/.bashrc # 重载用户环境变量中
首先进入 wsl 找到一个合适的目录
# 拉取构建使用的虚拟机
mkdir ~/software ~/module
cd ~/software
wget https://github.com/gluonhq/graal/releases/download/gluon-22.1.0.1-Final/graalvm-svm-java17-linux-gluon-22.1.0.1-Final.tar.gz
cd ~/module
tar -zxvf ../software/graalvm-svm-java17-linux-gluon-22.1.0.1-Final.tar.gz
graalvm 是一个特殊的 java 虚拟机环境,主要是使用AOT模打包构建多个平台的虚拟机版本,它可以直接当做一个普通的 jdk 使用
cd ~/software
wget https://dlcdn.apache.org/maven/maven-3/3.9.9/binaries/apache-maven-3.9.9-bin.tar.gz
cd ~/module
tar -zxvf ../software/apache-maven-3.9.9-bin.tar.gz
修改 maven settings 文件
vi ~/module/apache-maven-3.9.9-bin/conf/settings.xml
<!-- 添加镜像 -->
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
<mirror>
<id>repo2</id>
<mirrorOf>central</mirrorOf>
<name>Human Readable Name for this Mirror.</name>
<url>http://repo2.maven.org/maven2/</url>
</mirror>
vi ~/.bashrc # 编辑到用户环境变量中
export GRAALVM_HOME=~/module/graalvm-svm-java17-linux-gluon-22.1.0.1-Final
## JAVA_HOME
export JAVA_HOME=$GRAALVM_HOME
export PATH=$PATH:$JAVA_HOME/bin
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
export MVN_HOME=~/module/apache-maven-3.9.9
export PATH=$PATH:$MVN_HOME/bin
source ~/.bashrc # 重载用户环境变量中
这里基本的环境已经配置好了,至于 andriod sdk 这里不用显式的去配置,因为 gluonfx 这个工具会在打包的过程中自动的下载相关的依赖,对这个 andriodSdk 非必须。
具体可以参考Gluon 官网文档
准备一个专门执行 gluonfx 编译安卓的脚本
mkdir ~/bin
vi ~/bin/gluon_build_android
chmod +x ~/bin/gluon_build_android
source ~/.bashrc # 重载用户环境变量中
~/bin/gluon_build_android
的内容如下
mvn clean package -DskipTests=true
mvn -P android gluonfx:build gluonfx:package -DskipTests=true
拉取官网示例项目 HelloFx
mkdir ~/module/git-repos
cd ~/module/git-repos
git clone https://github.com/gluonhq/gluon-samples.git
cd gluon-samples/HelloFx
gluon_build_android # 执行之前定义的脚本