这个问题可能是同一个问题的这一个,但现在看来,一个的提问者还没有添加足够的信息来获得一个有用的响应。
我正在尝试使用JDK和JavaFx SDK版本11.0.2运行JavaFx应用程序。
此代码完全按预期工作,从而产生一个空窗口:
import javafx.application.Application; import javafx.scene.Scene; import javafx.scene.layout.StackPane; import javafx.stage.Stage; public class Main extends Application { public void start(Stage primaryStage) throws Exception { StackPane root = new StackPane(); primaryStage.setScene(new Scene(root, 420, 420)); primaryStage.show(); } public static void main(String[] args) { launch(args); } }
但是,如果我尝试向添加标签StackPane,则会引发异常。
import ... import javafx.scene.control.Label; public class Main extends Application { public void start(Stage primaryStage) throws Exception { StackPane root = new StackPane(); root.getChildren().add(new Label("42")); primaryStage.setScene(new Scene(root, 420, 420)); primaryStage.show(); } public static void main(String[] args) { launch(args); } }
它产生的堆栈跟踪如下所示(Main中的第13行是创建Label的位置):
Exception in Application start method java.lang.reflect.InvocationTargetException at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.base/java.lang.reflect.Method.invoke(Method.java:566) at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:464) at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:363) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.base/java.lang.reflect.Method.invoke(Method.java:566) at java.base/sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.java:1051) Caused by: java.lang.RuntimeException: Exception in Application start method at javafx.graphics/com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:900) at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication$2(LauncherImpl.java:195) at java.base/java.lang.Thread.run(Thread.java:834) Caused by: java.lang.IllegalAccessError: superclass access check failed: class com.sun.javafx.scene.control.ControlHelper (in unnamed module @0xbbd2743) cannot access class com.sun.javafx.scene.layout.RegionHelper (in module javafx.graphics) because module javafx.graphics does not export com.sun.javafx.scene.layout to unnamed module @0xbbd2743 at java.base/java.lang.ClassLoader.defineClass1(Native Method) at java.base/java.lang.ClassLoader.defineClass(ClassLoader.java:1016) at java.base/java.security.SecureClassLoader.defineClass(SecureClassLoader.java:174) at java.base/jdk.internal.loader.BuiltinClassLoader.defineClass(BuiltinClassLoader.java:802) at java.base/jdk.internal.loader.BuiltinClassLoader.findClassOnClassPathOrNull(BuiltinClassLoader.java:700) at java.base/jdk.internal.loader.BuiltinClassLoader.loadClassOrNull(BuiltinClassLoader.java:623) at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:581) at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178) at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:521) at javafx.scene.control.Control.<clinit>(Control.java:86) at sample.Main.start(Main.java:13) at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$9(LauncherImpl.java:846) at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runAndWait$12(PlatformImpl.java:455) at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater$10(PlatformImpl.java:428) at java.base/java.security.AccessController.doPrivileged(Native Method) at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater$11(PlatformImpl.java:427) at javafx.graphics/com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96) at javafx.graphics/com.sun.glass.ui.gtk.GtkApplication._runLoop(Native Method) at javafx.graphics/com.sun.glass.ui.gtk.GtkApplication.lambda$runLoop$11(GtkApplication.java:277) ... 1 more Exception running application sample.Main
我正在Kubuntu上运行IntelliJ Idea的最新版本。我从官方网站下载了Oracle JDK和JavaFX
Oracle JDK和JavaFX
我放在javafx-sdk-11.0.2目录中/usr/lib/jvm/,jdk-11.0.2并且在同一目录中。
javafx-sdk-11.0.2
/usr/lib/jvm/
jdk-11.0.2
我相信在IntelliJ Idea中,我已经正确选择了JDK,并且已将其添加/usr/lib/jvm/javafx-sdk-11.0.2/lib为库。
IntelliJ Idea
/usr/lib/jvm/javafx-sdk-11.0.2/lib
IntelliJ Idea正在使用此命令来启动应用程序(为提高可读性而拆分):
/usr/lib/jvm/jdk-11.0.2/bin/java -Djava.library.path=/usr/lib/jvm/javafx-sdk-11.0.2/lib --add-modules javafx.base,javafx.graphics --add-reads javafx.base=ALL-UNNAMED --add-reads javafx.graphics=ALL-UNNAMED -javaagent:/opt/jetbrains/idea-IU-183.4886.37/lib/idea_rt.jar=36031:/opt/jetbrains/idea-IU-183.4886.37/bin -Dfile.encoding=UTF-8 -classpath /home/rm/IdeaProjects/JfxPlayground/out/production/JfxPlayground :/usr/lib/jvm/javafx-sdk-11.0.2/lib/src.zip :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx-swt.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.web.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.base.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.fxml.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.media.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.swing.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.controls.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.graphics.jar -p /usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.base.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.graphics.jar sample.Main
我尚未修改任何VM选项。
如何解决此错误?这是JavaFx中的错误吗?
你已经在说明问题了:
由于JavaFX 11不再是JDK的一部分,因此你必须从此处使用JavaFX SDK(如你所做的那样),或者使用Maven / Gradle从Maven Central检索JavaFX模块。
然后,你需要将SDK添加为库,以便IntelliJ可以找到JavaFX类。
但是,一旦做到了这一点,并且考虑到JavaFX jar是模块,那么你仍然需要做两件事:
JavaFX jar
根据你的IntelliJ输出,它在默认情况下添加javafx.graphics和javafx.base:
IntelliJ
javafx.graphics
javafx.base
--add-modules javafx.base,javafx.graphics -p /usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.base.jar :/usr/lib/jvm/javafx-sdk-11.0.2/lib/javafx.graphics.jar
(请注意-p与相同–module-path)
-p
module-path
这说明了为什么你的项目在第一种情况下运行,即当你没有将控件添加到场景中时,仅运行StackPane属于javafx.graphics 模块的控件,而在添加时添加了Label属于javafx.controls 模块的控件时,失败并显示已发布的异常。
已经说过很多次了:你需要为项目设置所需的VM选项。
首先阅读https://openjfx.io/openjfx-docs/上的文档,包括IntelliJ文档,IDE的非模块化项目部分。并阅读第4部分。添加VM选项。
https://openjfx.io/openjfx-docs/
因此,单击运行->编辑配置,然后添加:
-p /usr/lib/jvm/javafx-sdk-11.0.2/lib --add-modules javafx.controls
应用并运行,该问题将得到解决。