web-dev-qa-db-ja.com

JavaFX、OS X、グラフィックスデバイスの初期化に失敗しました:es2、sw

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

プロジェクトを機能させるにはどうすればよいですか?

5
Aphro Disiac

JavaFX11を使用してHelloWorldを実行する のドキュメントに記載されているように、プロジェクトを開始するための最初のステップは次のとおりです。

ダウンロード 適切なJavaFXランタイムオペレーティングシステムに適切なものを使用して、目的の場所に解凍します。

以前に別のユーザーから提供されたlibフォルダーを使用しようとしていたときに、リンクを新しいプラットフォーム固有のダウンロード済みSDKの/libフォルダーに変更することで解決しました。

理由libへの引数として指定するmodulepathフォルダーにSDKにバンドルされているダイナミックライブラリがあります。これらのライブラリはプラットフォームごとにバンドルされているため、クロスプラットフォームで使用されるSDKまたはlibフォルダーは、アプリケーションの起動時にロードするエラーに記載されているような動的ライブラリを提供できません。

3
nullpointer

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

0
Martin Mähly

私は最近同じ問題を抱えていました、そしてそれが何であるかを理解しようと何日も試みた後、そしていくつかの困惑した後、私はそれを修正しました!。

それらすべての.dylibファイルは許可が必要なようです!

Javafx libフォルダーに移動し、最初にすべてのファイルがそこにあることを確認します。 (8 jar、13 dylib、1 Zip、および1プロパティファイル)。そうでない場合は、GluonのWebサイトから再ダウンロードしてください。

次に、すべてのファイルを選択して右クリックし、[プログラムから開く]を選択して、[ターミナル]を選択します。開くかキャンセルするかを尋ねられます...すべてのアラートウィンドウで[開く]をクリックします。完了したら、プロジェクトを再度実行してみてください。今回は機能します。

どうしてこんなものが必要なのかしら、どこにも見つからない!

私はこの問題を抱えているすべての人がそれを修正することを願っています。

0
Beni Rodriguez