使用Graal,Gradle和Gluon Client的本地图像不会加载我的主要FXML [Windows]

如何解决使用Graal,Gradle和Gluon Client的本地图像不会加载我的主要FXML [Windows]

这与我的第一个问题有关,但是自从我进一步了解以来,这个问题有了很大的改变。我无法在本机映像和Windows上找到有关此问题(看似简单的问题)的信息。

情况:IntelliJ运行我的应用程序,创建可执行的Jar也可以正常运行。

问题:我在本地图像的主FXML上遇到loadexception。这不是“位置未设置”错误,因此我认为这不是运行时类路径问题。

我的想法:由于Jar的问题是运行时类路径,因此本机映像是否仍然如此?如果是这样,如何在gluonClient {}路径中设置它?

解决方案:在@JoséPereda的帮助下,问题是一个不完整的ReflectionList。将stacktrace添加到catch块中后,我仍然需要添加“找不到的类”。我的困惑来自于事实,那就是jar和IntelliJ都不是问题。我有一些阅读要做。 :)

错误

[Fri Oct 02 19:34:12 CEST 2020][INFO] ==================== RUN TASK ====================
[Fri Oct 02 19:34:12 CEST 2020][FINE] PB Command for run until end: C:\Users\vince\Documents\Company\Company-APP\Programming\Java\Projects\AstroPixelProcessor-javafx\build\client\x86_64-windows\AstroPixelProcessor-javafx.exe
[Fri Oct 02 19:34:12 CEST 2020][FINE] Start process run until end...
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] There was a problem loading the main view fxml; javafx.fxml.LoadException: 
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] views/MainView.fxml
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] 
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] Exception in Application start method
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] Something went wrong with launching the JavaFX runtime.
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] java.lang.RuntimeException: Exception in Application start method
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:900)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.LauncherImpl.lambda$launchApplication$2(LauncherImpl.java:195)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at java.lang.Thread.run(Thread.java:834)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.oracle.svm.core.thread.JavaThreads.threadStartRoutine(JavaThreads.java:517)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.oracle.svm.core.windows.WindowsJavaThreads.osThreadStartRoutine(WindowsJavaThreads.java:138)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB] Caused by: java.lang.NullPointerException
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.astropixelprocessor.APP.start(APP.java:41)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$9(LauncherImpl.java:846)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$12(PlatformImpl.java:455)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.PlatformImpl.lambda$runLater$10(PlatformImpl.java:428)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at java.security.AccessController.doPrivileged(AccessController.java:101)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.PlatformImpl.lambda$runLater$11(PlatformImpl.java:427)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.oracle.svm.jni.JNIJavaCallWrappers.jniInvoke_VA_LIST:Ljava_lang_Runnable_2_0002erun_00028_00029V(JNIJavaCallWrappers.java:0)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.glass.ui.win.WinApplication._runLoop(WinApplication.java)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     at com.sun.glass.ui.win.WinApplication.lambda$runLoop$3(WinApplication.java:174)
[Fri Oct 02 19:34:12 CEST 2020][FINE] [SUB]     ... 3 more
[Fri Oct 02 19:34:12 CEST 2020][FINE] Result for run until end: 0

Build.gradle

plugins {
    id 'java'
    id 'application'
    id 'distribution'
    id 'org.openjfx.javafxplugin' version '0.0.9'
    id 'com.gluonhq.client-gradle-plugin' version '0.1.31'
    id 'org.beryx.jlink' version '2.12.0'
}

repositories {
    mavenCentral()
}

dependencies {
    testImplementation('junit:junit:4.13')
}

group 'com.ariesproductions'
version '1.0-SNAPSHOT'
sourceCompatibility = 11
mainClassName = 'com.astropixelprocessor.Main'

javafx {
    version = '15'
    modules = ['javafx.controls','javafx.fxml']
}

gluonClient {
    reflectionList = ["com.astropixelprocessor.APP"]
}

jar {
    manifest {
        attributes 'Main-Class': 'com.astropixelprocessor.Main'
    }
    from {
        configurations.runtimeClasspath.collect { it.isDirectory() ? it : zipTree(it) }
    }
}

这是相关课程

public class APP extends Application {

    private static final String mainViewTitle = "my app";
    private static final String mainViewPath = "/views/MainView.fxml";
    private static final String themePath = "/dark-theme.css";

    private Stage primaryStage;

    public APP() {}

    public void show(){
        launch();
    }

    // JavaFX start method,application entry point
    @Override
    public void start(Stage primaryStage) {

        this.primaryStage = primaryStage;

        FXMLLoader primarySceneViewLoader = new FXMLLoader(getClass().getResource(mainViewPath));

        Parent primarySceneRootNode = null;

        try {
            primarySceneRootNode = primarySceneViewLoader.load();
        } catch (Exception e) {
            System.err.println("There was a problem loading the main view fxml; " + e.toString());
        }

        assert primarySceneRootNode != null;
        primarySceneRootNode.getStylesheets().add(String.valueOf(getClass().getResource(themePath)));

        primaryStage.setTitle(mainViewTitle);
        primaryStage.setScene(new Scene(primarySceneRootNode));

        try {
            primaryStage.show();
        } catch (IllegalStateException e) {
            System.err.println("The primary stage show method is called on a thread other than the JavaFX Application Thread.");
            e.printStackTrace();
        }

        // Catch the application close event and display a quit stage
        primaryStage.setOnCloseRequest(windowEvent ->

        {
            // Stop the system from acting on this event
            windowEvent.consume();
            SimpleAlertViewController.showQuitStage();
        });
    }
}

我的主视图fxml的一部分

<VBox fx:id="mainWindow" xmlns="http://javafx.com/javafx/11.0.1" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.astropixelprocessor.controllers.MainViewController">
    <MenuBar prefWidth="1280.0" VBox.vgrow="NEVER">
        <Menu mnemonicParsing="false" text="File">
            <MenuItem mnemonicParsing="false" text="New" />
            <MenuItem mnemonicParsing="false" text="Open…" />
            <Menu mnemonicParsing="false" text="Open Recent" />
            <SeparatorMenuItem mnemonicParsing="false" />
            <MenuItem mnemonicParsing="false" text="Close" />
            <MenuItem mnemonicParsing="false" text="Save" />
            <MenuItem mnemonicParsing="false" text="Save As…" />
            <MenuItem mnemonicParsing="false" text="Revert" />
            <SeparatorMenuItem mnemonicParsing="false" />
            <MenuItem mnemonicParsing="false" text="Preferences…" />
            <SeparatorMenuItem mnemonicParsing="false" />
            <MenuItem fx:id="quitMenuItem" mnemonicParsing="false" onAction="#menuHandler" text="Quit">
            <accelerator>
               <KeyCodeCombination alt="UP" code="Q" control="UP" meta="UP" shift="UP" shortcut="DOWN" />
            </accelerator></MenuItem>
        </Menu>

关于loadexception的额外堆栈跟踪

[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB] javafx.fxml.LoadException: 
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB] views/MainView.fxml
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB] 
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.constructLoadException(FXMLLoader.java:2629)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.importClass(FXMLLoader.java:2867)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.processImport(FXMLLoader.java:2711)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.processProcessingInstruction(FXMLLoader.java:2680)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2546)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.loadImpl(FXMLLoader.java:2470)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.load(FXMLLoader.java:2439)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.astropixelprocessor.APP.start(APP.java:35)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$9(LauncherImpl.java:846)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$12(PlatformImpl.java:455)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.PlatformImpl.lambda$runLater$10(PlatformImpl.java:428)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at java.security.AccessController.doPrivileged(AccessController.java:101)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.javafx.application.PlatformImpl.lambda$runLater$11(PlatformImpl.java:427)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.oracle.svm.jni.JNIJavaCallWrappers.jniInvoke_VA_LIST:Ljava_lang_Runnable_2_0002erun_00028_00029V(JNIJavaCallWrappers.java:0)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.glass.ui.win.WinApplication._runLoop(WinApplication.java)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.sun.glass.ui.win.WinApplication.lambda$runLoop$3(WinApplication.java:174)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at java.lang.Thread.run(Thread.java:834)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.oracle.svm.core.thread.JavaThreads.threadStartRoutine(JavaThreads.java:517)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.oracle.svm.core.windows.WindowsJavaThreads.osThreadStartRoutine(WindowsJavaThreads.java:138)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB] Caused by: java.lang.ClassNotFoundException: javafx.scene.control.ComboBox
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at com.oracle.svm.core.hub.ClassForNameSupport.forName(ClassForNameSupport.java:60)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at java.lang.ClassLoader.loadClass(ClassLoader.java:233)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.loadTypeForPackage(FXMLLoader.java:2935)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.loadType(FXMLLoader.java:2924)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     at javafx.fxml.FXMLLoader.importClass(FXMLLoader.java:2865)
[Sat Oct 03 13:50:21 CEST 2020][FINE] [SUB]     ... 18 more

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-