使用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 (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...