IntelliJ IDEAでJavaFXプロジェクトを作成しようとしていますが、毎回エラーが発生します。
チュートリアルを完了した後 https://openjfx.io/openjfx-docs/#IDE-Intellij 、私はこれを持っています:
Graphics Device initialization failed for : es2, sw
Error initializing QuantumRenderer: no suitable pipeline found
Java.lang.RuntimeException: Java.lang.RuntimeException: Error initializing QuantumRenderer: no suitable pipeline found
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer.getInstance(QuantumRenderer.Java:280)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumToolkit.init(QuantumToolkit.Java:222)
at javafx.graphics/com.Sun.javafx.tk.Toolkit.getToolkit(Toolkit.Java:260)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:267)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:158)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.startToolkit(LauncherImpl.Java:658)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.Java:409)
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: Error initializing QuantumRenderer: no suitable pipeline found
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.init(QuantumRenderer.Java:94)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.run(QuantumRenderer.Java:124)
at Java.base/Java.lang.Thread.run(Thread.Java:834)
Exception in thread "main" 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 Java.base/Sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.Java:1051)
Caused by: Java.lang.RuntimeException: No toolkit found
at javafx.graphics/com.Sun.javafx.tk.Toolkit.getToolkit(Toolkit.Java:272)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:267)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:158)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.startToolkit(LauncherImpl.Java:658)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.Java:409)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.Java:363)
... 5 more
Process finished with exit code 1
-Dprism.verbose = trueをVM IntelliJのオプションIDEA(したがって、私のVMオプションは次のようになります:
--module-path /myPath/javafx-sdk-11.0.1/lib --add-modules=javafx.controls,javafx.fxml -Dprism.verbose=true
そして、私はこの出力を取得します:
Prism pipeline init order: es2 sw
Using Double Precision Marlin Rasterizer
Using dirty region optimizations
Not using texture mask for primitives
Not forcing power of 2 sizes for textures
Using hardware CLAMP_TO_ZERO mode
Opting in for HiDPI pixel scaling
Prism pipeline name = com.Sun.prism.es2.ES2Pipeline
Loading ES2 native library ... prism_es2
GraphicsPipeline.createPipeline failed for com.Sun.prism.es2.ES2Pipeline
Java.lang.UnsatisfiedLinkError: no prism_es2 in Java.library.path: [/Users/Lisa/javafx-sdk-11.0.1/lib]
at Java.base/Java.lang.ClassLoader.loadLibrary(ClassLoader.Java:2660)
at Java.base/Java.lang.Runtime.loadLibrary0(Runtime.Java:829)
at Java.base/Java.lang.System.loadLibrary(System.Java:1867)
at javafx.graphics/com.Sun.glass.utils.NativeLibLoader.loadLibraryInternal(NativeLibLoader.Java:150)
at javafx.graphics/com.Sun.glass.utils.NativeLibLoader.loadLibrary(NativeLibLoader.Java:52)
at javafx.graphics/com.Sun.prism.es2.ES2Pipeline.lambda$static$0(ES2Pipeline.Java:68)
at Java.base/Java.security.AccessController.doPrivileged(Native Method)
at javafx.graphics/com.Sun.prism.es2.ES2Pipeline.<clinit>(ES2Pipeline.Java:50)
at Java.base/Java.lang.Class.forName0(Native Method)
at Java.base/Java.lang.Class.forName(Class.Java:315)
at javafx.graphics/com.Sun.prism.GraphicsPipeline.createPipeline(GraphicsPipeline.Java:187)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.init(QuantumRenderer.Java:91)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.run(QuantumRenderer.Java:124)
at Java.base/Java.lang.Thread.run(Thread.Java:834)
*** Fallback to Prism SW pipeline
Prism pipeline name = com.Sun.prism.sw.SWPipeline
GraphicsPipeline.createPipeline failed for com.Sun.prism.sw.SWPipeline
Java.lang.UnsatisfiedLinkError: no prism_sw in Java.library.path: [/Users/Lisa/javafx-sdk-11.0.1/lib]
at Java.base/Java.lang.ClassLoader.loadLibrary(ClassLoader.Java:2660)
at Java.base/Java.lang.Runtime.loadLibrary0(Runtime.Java:829)
at Java.base/Java.lang.System.loadLibrary(System.Java:1867)
at javafx.graphics/com.Sun.glass.utils.NativeLibLoader.loadLibraryInternal(NativeLibLoader.Java:150)
at javafx.graphics/com.Sun.glass.utils.NativeLibLoader.loadLibrary(NativeLibLoader.Java:52)
at javafx.graphics/com.Sun.prism.sw.SWPipeline.lambda$static$0(SWPipeline.Java:42)
at Java.base/Java.security.AccessController.doPrivileged(Native Method)
at javafx.graphics/com.Sun.prism.sw.SWPipeline.<clinit>(SWPipeline.Java:41)
at Java.base/Java.lang.Class.forName0(Native Method)
at Java.base/Java.lang.Class.forName(Class.Java:315)
at javafx.graphics/com.Sun.prism.GraphicsPipeline.createPipeline(GraphicsPipeline.Java:187)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.init(QuantumRenderer.Java:91)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.run(QuantumRenderer.Java:124)
at Java.base/Java.lang.Thread.run(Thread.Java:834)
Graphics Device initialization failed for : es2, sw
Error initializing QuantumRenderer: no suitable pipeline found
Java.lang.RuntimeException: Java.lang.RuntimeException: Error initializing QuantumRenderer: no suitable pipeline found
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer.getInstance(QuantumRenderer.Java:280)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumToolkit.init(QuantumToolkit.Java:222)
at javafx.graphics/com.Sun.javafx.tk.Toolkit.getToolkit(Toolkit.Java:260)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:267)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:158)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.startToolkit(LauncherImpl.Java:658)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.Java:409)
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: Error initializing QuantumRenderer: no suitable pipeline found
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.init(QuantumRenderer.Java:94)
at javafx.graphics/com.Sun.javafx.tk.quantum.QuantumRenderer$PipelineRunnable.run(QuantumRenderer.Java:124)
at Java.base/Java.lang.Thread.run(Thread.Java:834)
Exception in thread "main" 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 Java.base/Sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.Java:1051)
Caused by: Java.lang.RuntimeException: No toolkit found
at javafx.graphics/com.Sun.javafx.tk.Toolkit.getToolkit(Toolkit.Java:272)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:267)
at javafx.graphics/com.Sun.javafx.application.PlatformImpl.startup(PlatformImpl.Java:158)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.startToolkit(LauncherImpl.Java:658)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.Java:409)
at javafx.graphics/com.Sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.Java:363)
... 5 more
Process finished with exit code 1
プロジェクトを機能させるにはどうすればよいですか?
JavaFX11を使用してHelloWorldを実行する のドキュメントに記載されているように、プロジェクトを開始するための最初のステップは次のとおりです。
ダウンロード 適切なJavaFXランタイムオペレーティングシステムに適切なものを使用して、目的の場所に解凍します。
以前に別のユーザーから提供されたlibフォルダーを使用しようとしていたときに、リンクを新しいプラットフォーム固有のダウンロード済みSDKの/lib
フォルダーに変更することで解決しました。
理由:lib
への引数として指定するmodulepath
フォルダーにSDKにバンドルされているダイナミックライブラリがあります。これらのライブラリはプラットフォームごとにバンドルされているため、クロスプラットフォームで使用されるSDKまたはlibフォルダーは、アプリケーションの起動時にロードするエラーに記載されているような動的ライブラリを提供できません。
jlink
のビルド結果を実行しようとすると、まさにこのエラーが発生しました。その理由は、--module-path
のタイプミスでした。これの症状は、
libprism_common.dylib、libprism_es2.dylib、libprism_sw.dylib、libjavafx_font.dylib、libjavafx_iio.dylib
(およびその他のいくつか)は、ビルド結果のlib/
フォルダーにありません。
したがって、示されたモジュールパスに実際にopenjfx
モジュールが含まれていることを確認することをお勧めします。
javafx.base.jmod、javafx.controls.jmod、javafx.fxml.jmod、
javafx.graphics.jmod、javafx.media.jmod、javafx.swing.jmod、
javafx.web.jmod
私は最近同じ問題を抱えていました、そしてそれが何であるかを理解しようと何日も試みた後、そしていくつかの困惑した後、私はそれを修正しました!。
それらすべての.dylibファイルは許可が必要なようです!
Javafx libフォルダーに移動し、最初にすべてのファイルがそこにあることを確認します。 (8 jar、13 dylib、1 Zip、および1プロパティファイル)。そうでない場合は、GluonのWebサイトから再ダウンロードしてください。
次に、すべてのファイルを選択して右クリックし、[プログラムから開く]を選択して、[ターミナル]を選択します。開くかキャンセルするかを尋ねられます...すべてのアラートウィンドウで[開く]をクリックします。完了したら、プロジェクトを再度実行してみてください。今回は機能します。
どうしてこんなものが必要なのかしら、どこにも見つからない!
私はこの問題を抱えているすべての人がそれを修正することを願っています。