开发工具,能力强的伙伴可以直接参考官方文档

简介: 该教程详细介绍了如何使用Gluon将JavaFX项目编译成exe文件,涵盖开发工具配置、环境搭建及异常处理。开发工具包括Idea 2023.3、Gluon插件、Git和Maven等。环境搭建需安装VS 2022 Community、JDK 11或17+及GraalVM CE Gluon 22.1.0.1-Final,并配置相应环境变量。通过拉取示例项目、修改`pom.xml`并执行`build.bat`完成编译。教程还提供了异常处理及将编译动作绑定到Maven生命周期的方法。

Gluon 编译 JavaFx -> exe
能力强的伙伴可以直接参考官方文档

开发工具
idea 2023.3
idea gluon plugin
git
apache-maven-3.8.4
环境准备
vs 2022 community 版本 (使用微软官方的安装器安装,社区版即可)
jdk 11 or 17+ (可以使用idea进行下载安装)
GraalVM CE Gluon 22.1.0.1-Final
vs 2022的安装明细
(来自官网文档/platforms/windows这一节)

可以参考我的安装明细

以上步骤之后,新增一个路径到Path环境变量中

(因为后续编译的时候,会用到这个路径下的cl,默认没有添加到path,下面的版本号 14.29.30133根据自己的安装情况设置)

C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.29.30133\bin\HostX86\x86
配置上jdk环境变量

新增环境变量

JAVA_HOME=D:\development\env\java\openjdk-21.0.2
CLASSPATH=.;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar

Path新增条目

%JAVA_HOME%\bin
%JAVA_HOME%\jre\bin
安装GraalVM CE Gluon 22.1.0.1-Final
下载解压到合适的目录后配置好环境变量

GRAALVM_HOME=D:\development\env\java\graalvm-svm-java17-windows-gluon-22.1.0.1-Final
编译官网示例项目
(到这里,我默认你的环境已经安装了git、mvn等工具,并配置相应的环境变量,且以上的步骤都没有问题)

拉取项目到本地

git clone https://github.com/gluonhq/gluon-samples.git
使用idea打开项目,设置项目的jdk为17+,给文件 gluon-samples/HelloFX/pom.xml文件增加几个build配置项


hellofx.HelloFX
host
1.0.23
0.0.8




org.apache.maven.plugins
maven-compiler-plugin
3.8.1

17
17
17
utf-8




org.openjfx
javafx-maven-plugin
${javafx.maven.plugin.version}

${main.class}




com.gluonhq
gluonfx-maven-plugin
${gluonfx.maven.plugin.version}

${gluonfx.target}
${main.class}

. \.db$
.\.xlsx$





新建build.bat文件
在项目路径 gluon-samples/HelloFX新建一个build.bat文件

call "C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvars64.bat"
mvn gluonfx:build -DskipTests=true -P desktop
执行编译
cd 项目路径
./build.bat
查看结果
编译结果输出到了 gluon-samples\HelloFX\target\gluonfx\x86_64-windows


异常处理
1.java.io.IOException: Cannot run program "cl" (in directory "D:\workspace\code\mycode\Gluon\gluon-samples\HelloFX\target\gluonfx\x86_64-windows\gvm\HelloFX"): CreateProcess error=2, 系统找不到指定的文件。
出现这个异常是因为上面的cl指令路径没有添加到path环境变量中

2.java.lang.IllegalArgumentException: We currently can't compile to aarch64-linux-android when running on x86_64-microsoft-windows
这个异常是编译在x86_64的环境中编译aarch64-linux-android,我们搭建的环境只能编译exe,导致这个错误的原因是项目的profiles设置如下


而且是直接到



这里面去执行的编译,在这里执行没有预先执行vcvars64.bat,这也是前面写那个build脚本的原因

修复方法就是将项目profiles选择为desktop,同时使用脚本去执行。

将desktop编译动作绑定packge到生命周期
这样会将build脚本执行和package进行捆绑


true



ios

ios



android

android



desktop

true


desktop
false
host





//代码效果参考: https://www.h3cw.com/sitemap/post.xml

org.codehaus.mojo
exec-maven-plugin
3.0.0


run-prepare-env
package

exec


./bin/build.bat






${skip.exec}



org.apache.maven.plugins
maven-compiler-plugin
3.8.1



org.openjfx
javafx-maven-plugin
${javafx.plugin.version}

${mainClassName}




com.gluonhq
gluonfx-maven-plugin
${gluonfx.plugin.version}

${gluonfx.target}

display
lifecycle
statusbar
storage


com.xxx.PrimaryPresenter
com.xxx.SecondaryPresenter

${mainClassName}



分类: javafx
标签: gluon , javafx

相关文章
|
缓存 负载均衡 Linux
内核:进程与调度机制(笔记)
内核:进程与调度机制(笔记)
267 0
|
设计模式 架构师 大数据
我的架构师之路——阿里云 MVP 沈剑
沈剑,公众号“架构师之路”的作者,曾任百度高级工程师和58同城高级架构师、技术委员会主席、技术学院优秀讲师,现为到家集团技术委员会主席和技术VP,同时也是快狗打车(原58速运)的CTO。本文是沈剑老师在阿里云的直播中分享的一些自己关于架构师的看法和成为架构师的心路历程的第一部分。
6685 0
我的架构师之路——阿里云 MVP 沈剑
|
SQL Oracle 关系型数据库
|
5月前
|
测试技术 持续交付 开发工具
吞噬混沌:CodeBuddy与流程利刃,斩破游戏开发的蛮荒时代(二)
本文参加CodeBuddy「首席试玩官」大赛,探讨游戏开发流程规范与智能工具赋能。文章涵盖质量保障体系(每日构建、代码审查、测试会议)、开发工具链、紧急情况处理(热修复与回滚机制)及代码风格指南。重点介绍CodeBuddy在各环节的作用:优化构建、智能评审、加速修复、保障风格一致等。作为贯穿生命周期的智能助手,CodeBuddy连接工具链、提升效率、沉淀经验,助力团队实现高质量开发目标。未来游戏开发需结合规范与技术,CodeBuddy将成为不可或缺的智能向导。
186 7
|
Ubuntu Linux
Fedora 36 ARM 镜像源更换与软件安装
Fedora 36是Linux发行版,由社区开发,红帽赞助。安装软件通常用DNF(RPM包)。若需安装.deb包,先用alien转换。遇到问题时,可删除`/etc/yum.repo.d`目录内容,改用阿里云镜像源,如: 简而言之,Fedora 36的软件安装涉及DNF或alien,镜像源更换解决安装问题,阿里云镜像提供速度优化。
705 9
|
12月前
|
JSON 安全 fastjson
高性能 JSON 处理:为何选择 Fastjson?
Fastjson 是由阿里巴巴集团开发的一个高性能的 JSON 处理库,它支持 Java 对象与 JSON 字符串之间的互相转换。
1348 0
高性能 JSON 处理:为何选择 Fastjson?
|
安全 Java Maven
优化Maven镜像配置:使用阿里云加速依赖下载
更新Maven镜像配置至关重要,尤其使用阿里云仓库时。在`settings.xml`中加入特定镜像配置可显著提升依赖下载速度。示例配置指定了阿里云镜像ID、替代表态仓库、安全的URL、默认布局及启用版本管理。需定位至用户目录下的`.m2/`文件夹编辑`settings.xml`,添加镜像信息后保存测试。若下载仍慢,考虑网络状况或备选镜像。多镜像设置时需注意避免冲突。
2191 3
|
前端开发 Linux API
Avalonia:一个.NET跨平台UI框架
Avalonia:一个.NET跨平台UI框架
575 0
|
XML 前端开发 数据可视化
最新版scene-builder安装
最新版scene-builder安装
317 1