问题描述
这与我的第一个问题有关,但是自从我进一步了解以来,这个问题有了很大的改变。我无法在本机映像和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 (将#修改为@)