
javafx 本身不原生支持 android,但借助 gluon mobile 工具链,开发者可将 javafx 应用跨平台编译为原生 android(及 ios)应用;本文详解从环境搭建、项目配置到构建 apk 的完整流程。
JavaFX 是一个功能强大的桌面端 UI 框架,但它并不直接支持 Android 平台——标准 OpenJDK + JavaFX SDK(如你当前在 VS Code 中安装的)仅适用于 Windows/macOS/Linux 桌面环境。若想将 JavaFX 应用部署到 Android 设备,必须借助第三方工具链:Gluon Mobile。
Gluon Mobile 是一套开源、生产就绪的框架,它基于 GraalVM 和 JavaFXPorts 技术,将 Java/Kotlin 代码(含 JavaFX UI)编译为原生 ARM/AARCH64 二进制,并提供适配移动设备的控件(如 MobileApplication、BottomNavigation、Drawer)、生命周期管理、平台服务(摄像头、定位、通知等)以及完整的构建流水线。
✅ 正确路径如下:
-
安装必要工具链
立即学习“Java免费学习笔记(深入)”;
- JDK 17 或 21(LTS,推荐 Eclipse Temurin 或 Microsoft Build of OpenJDK)
- Apache Maven(≥3.9)
- Android SDK(含 platform-tools、build-tools、platforms;android-34、ndk;25.1.8937393)
- Gluon Client Plugin(通过 Maven 集成,无需单独安装 CLI)
-
创建 Gluon Mobile 项目(推荐使用 Maven Archetype)
在终端中运行:mvn archetype:generate \ -DarchetypeGroupId=com.gluonhq \ -DarchetypeArtifactId=client-archetype-mobile \ -DarchetypeVersion=0.1.19 \ -DgroupId=com.example \ -DartifactId=my-javafx-app \ -Dversion=1.0.0-SNAPSHOT
该命令生成一个预配置的多模块项目,含 src/main/java(共享逻辑)、src/main/resources(FXML/资源)和 client/src/android(Android 特定扩展)。
dmSOBC SHOP网店系统下载dmSOBC SHOP网店系统由北京时代胜腾信息技术有限公司(http://www.webzhan.com)历时6个月开发完成,本着简单实用的理念,商城在功能上摒弃了外在装饰的一些辅助功能,尽可能的精简各项模块开发,做到有用的才开发,网店V1.0.0版本开发完成后得到了很多用户的使用并获得了好评,公司立即对网店进行升级,其中包括修正客户提出的一些意见和建议,现对广大用户提供免费试用版本,如您在使用
-
在 VS Code 中打开并配置
-
编写 JavaFX 移动应用(关键差异)
不要继承 Application,而应继承 MobileApplication:public class MyApp extends MobileApplication { @Override public void init() { attachViewFactory("MainView", () -> new MainView()); } @Override public void postInit(Scene scene) { // 可在此注入 Material Design 主题 ((Stage) scene.getWindow()).setTitle("My Gluon App"); } }MainView 使用 View 类(非 Pane),并支持导航栈、状态保存等移动端语义。
-
构建与部署
运行以下命令生成签名 APK(首次会自动下载 Android NDK、交叉编译器等):mvn clean client:build -Pandroid mvn client:package -Pandroid
最终 APK 路径:client/target/client/aarch64-android/my-javafx-app-android.apk
⚠️ 注意事项:
- Gluon Mobile 不支持 FXML 的动态加载(FXMLLoader.load())在 Android 上运行,建议使用代码构建 UI 或预编译 FXML(需额外配置)。
- JavaFX CSS 功能受限,避免使用桌面专属属性(如 -fx-effect 复杂阴影);优先使用 Gluon 提供的 Stylesheets。
- 所有 Android 权限(如网络、存储)需在 client/src/android/AndroidManifest.xml 中显式声明。
- 调试建议使用 adb logcat | grep "MyApp" 查看日志,VS Code 的 Java Debug 插件暂不支持 Gluon 远程调试,推荐使用 Android Studio 分析 APK。
总结:JavaFX + Android 的可行路径唯一且成熟——Gluon Mobile。它不是“JavaFX 直接跑在 Android”,而是通过 GraalVM 将 Java 字节码 AOT 编译为原生 Android 应用,同时保留 JavaFX 的声明式 UI 体验。作为初学者,建议从 Gluon 官方 Quick Start(https://www.php.cn/link/74992087b6b1542bd4e45082d671a6ab)和示例仓库(https://www.php.cn/link/4328ad1978e9bcb7b297600e3019a5a6)入手,逐步替换你的桌面 JavaFX 项目结构,而非尝试“魔改”现有 SDK。









