web-dev-qa-db-ja.com

JavaFX 11:ラベル作成時のIllegalAccessError

この質問は、おそらく this one と同じ問題に関するものですが、その質問者は、役立つ応答を受け取るのに十分な情報を追加していないようです。

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はラベルが作成される場所です)。

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

IntelliJ Ideaの最新バージョンをKubuntuで実行しています。 Oracle JDKとJavaFXを公式Webサイトからダウンロードしました

javafx-sdk-11.0.2をディレクトリ/usr/lib/jvm/に配置し、jdk-11.0.2は同じディレクトリに配置します。

IntelliJのアイデアでは、私はJDKを正しく選択したと思います。ライブラリとして/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のバグですか?

18
Reinis Mazeiks

あなたはすでにあなたの問題の説明をしています:

VMオプションは変更していません。

JavaFX 11はJDKの一部ではなくなったため、JavaFX SDKを(現在のように) here から使用するか、Maven/Gradleを使用してMaven CentralからJavaFXモジュールを取得する必要があります。

次に、SDKをライブラリとして追加して、IntelliJがJavaFXクラスを見つけられるようにする必要があります。

しかし、それを行った後、JavaFX jarがモジュールであることを考えると、次の2つのことを行う必要があります。

  • JavaFXモジュールをモジュールパスで利用できるようにする
  • プロジェクトに追加するモジュールを定義します

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と同じであることに注意してください)

これは、最初のケースでプロジェクトが実行される理由を説明しています。シーンにコントロールが追加されていない場合、javafx.graphicsに属するStackPaneだけが module 、ただしjavafx.controlsmodule に属するLabelを追加すると、ポストされた例外で失敗します。

これは何度も言われてきました:プロジェクトに必要なVMオプションを設定する必要があります).

https://openjfx.io/openjfx-docs/ にある IntelliJ ドキュメントを含むドキュメントを読んでください。IDEの非モジュール式プロジェクトのセクション。そして、パート4を読みます。VMオプションを追加します。

VM Options

実行->構成の編集をクリックして、次を追加します。

-p /usr/lib/jvm/javafx-sdk-11.0.2/lib --add-modules javafx.controls

適用して実行すると、問題は解決されます。

19
José Pereda