JavaFX MediaPlayer 总是在 Linux 上抛出 InvocationTargetException(OpenJFX 11、15)
JavaFX MediaPlayer always throws InvocationTargetException on Linux (OpenJFX 11, 15)
我在 Linux (Ubuntu Budgie) 上的 JavaFX 媒体模块有问题。每次我尝试创建 javafx.scene.media.MediaPlayer
时,都会发生这种情况:
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(LauncherImpl.java:195)
at java.base/java.lang.Thread.run(Thread.java:834)
Caused by: MediaException: UNKNOWN : com.sun.media.jfxmedia.MediaException: Could not create player! : com.sun.media.jfxmedia.MediaException: Could not create player!
at javafx.media/javafx.scene.media.MediaException.exceptionToMediaException(MediaException.java:146)
at javafx.media/javafx.scene.media.MediaPlayer.init(MediaPlayer.java:518)
at javafx.media/javafx.scene.media.MediaPlayer.<init>(MediaPlayer.java:421)
at Test.MediaTest.start(MediaTest.java:18)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication1(LauncherImpl.java:846)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runAndWait(PlatformImpl.java:455)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(PlatformImpl.java:428)
at java.base/java.security.AccessController.doPrivileged(Native Method)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(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(GtkApplication.java:277)
... 1 more
Caused by: com.sun.media.jfxmedia.MediaException: Could not create player!
at javafx.media/com.sun.media.jfxmediaimpl.NativeMediaManager.getPlayer(NativeMediaManager.java:295)
at javafx.media/com.sun.media.jfxmedia.MediaManager.getPlayer(MediaManager.java:118)
at javafx.media/javafx.scene.media.MediaPlayer.init(MediaPlayer.java:474)
... 11 more
Exception running application Test.MediaTest
代码如下:
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.Pane;
import javafx.scene.media.Media;
import javafx.scene.media.MediaPlayer;
import javafx.scene.media.MediaView;
import javafx.stage.Stage;
public class MediaTest extends Application{
private static final String MEDIA_URL = "file:///home/michael/eclipse-workspace/JFXTest/VideoExample.mp4";
@Override
public void start(Stage stage) throws Exception {
Pane pane = new Pane();
pane.setPrefSize(640, 480);
Media media = new Media(MEDIA_URL);
MediaPlayer mediaPlayer = new MediaPlayer(media);
mediaPlayer.setOnReady(new Runnable(){
@Override
public void run() {
System.out.println(media.getWidth() +" x "+ media.getHeight() +" : "+ media.getDuration());
mediaPlayer.play();
}
});
Scene scene = new Scene(pane, 640, 480);
MediaView mediaView = new MediaView(mediaPlayer);
pane.getChildren().add(mediaView);
stage.setTitle("Why it doesn't work?");
stage.setScene(scene);
stage.show();
}
public static void main(String[] args) {
launch();
}
}
我知道 Whosebug 上有一些关于此问题的问题,但其中 none 个(我发现并检查过的)对我有帮助。
我试过了:
new Media(new File(MEDIA_URL).toURI().toString())
而不是 new Media(MEDIA_URL)
- Java教程默认
http://download.oracle.com/otndocs/products/javafx/oow2010-2.flv
代替本地视频
- 运行 在 OpenJFX 11 和 15 上
- 添加
jmods
- 正在安装 GStreamer(如 JavaFX 1.2 SDK Requirements 中所述)
- 我有
libavcodec58
和 libavformat58
(如 JavaFX 2 Certified System Configurations 中所述
- 我有
GLIB
2.31 (Ubuntu GLIBC 2.31-0ubuntu9.2)
我不知道还有什么我可能遗漏或做错的。如有任何帮助,我将不胜感激!
问题自行解决(嗯?)。
- 我添加了 JavaFX
jmod
s 而不是 jar
s 并重新编译了 => 没用;
- 将 JavaFX 16 (EA) 添加到类路径,然后将其删除 => 它起作用了,很奇怪...
我在 Linux (Ubuntu Budgie) 上的 JavaFX 媒体模块有问题。每次我尝试创建 javafx.scene.media.MediaPlayer
时,都会发生这种情况:
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(LauncherImpl.java:195)
at java.base/java.lang.Thread.run(Thread.java:834)
Caused by: MediaException: UNKNOWN : com.sun.media.jfxmedia.MediaException: Could not create player! : com.sun.media.jfxmedia.MediaException: Could not create player!
at javafx.media/javafx.scene.media.MediaException.exceptionToMediaException(MediaException.java:146)
at javafx.media/javafx.scene.media.MediaPlayer.init(MediaPlayer.java:518)
at javafx.media/javafx.scene.media.MediaPlayer.<init>(MediaPlayer.java:421)
at Test.MediaTest.start(MediaTest.java:18)
at javafx.graphics/com.sun.javafx.application.LauncherImpl.lambda$launchApplication1(LauncherImpl.java:846)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runAndWait(PlatformImpl.java:455)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(PlatformImpl.java:428)
at java.base/java.security.AccessController.doPrivileged(Native Method)
at javafx.graphics/com.sun.javafx.application.PlatformImpl.lambda$runLater(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(GtkApplication.java:277)
... 1 more
Caused by: com.sun.media.jfxmedia.MediaException: Could not create player!
at javafx.media/com.sun.media.jfxmediaimpl.NativeMediaManager.getPlayer(NativeMediaManager.java:295)
at javafx.media/com.sun.media.jfxmedia.MediaManager.getPlayer(MediaManager.java:118)
at javafx.media/javafx.scene.media.MediaPlayer.init(MediaPlayer.java:474)
... 11 more
Exception running application Test.MediaTest
代码如下:
import javafx.application.Application;
import javafx.scene.Scene;
import javafx.scene.layout.Pane;
import javafx.scene.media.Media;
import javafx.scene.media.MediaPlayer;
import javafx.scene.media.MediaView;
import javafx.stage.Stage;
public class MediaTest extends Application{
private static final String MEDIA_URL = "file:///home/michael/eclipse-workspace/JFXTest/VideoExample.mp4";
@Override
public void start(Stage stage) throws Exception {
Pane pane = new Pane();
pane.setPrefSize(640, 480);
Media media = new Media(MEDIA_URL);
MediaPlayer mediaPlayer = new MediaPlayer(media);
mediaPlayer.setOnReady(new Runnable(){
@Override
public void run() {
System.out.println(media.getWidth() +" x "+ media.getHeight() +" : "+ media.getDuration());
mediaPlayer.play();
}
});
Scene scene = new Scene(pane, 640, 480);
MediaView mediaView = new MediaView(mediaPlayer);
pane.getChildren().add(mediaView);
stage.setTitle("Why it doesn't work?");
stage.setScene(scene);
stage.show();
}
public static void main(String[] args) {
launch();
}
}
我知道 Whosebug 上有一些关于此问题的问题,但其中 none 个(我发现并检查过的)对我有帮助。
我试过了:
new Media(new File(MEDIA_URL).toURI().toString())
而不是new Media(MEDIA_URL)
- Java教程默认
http://download.oracle.com/otndocs/products/javafx/oow2010-2.flv
代替本地视频 - 运行 在 OpenJFX 11 和 15 上
- 添加
jmods
- 正在安装 GStreamer(如 JavaFX 1.2 SDK Requirements 中所述)
- 我有
libavcodec58
和libavformat58
(如 JavaFX 2 Certified System Configurations 中所述
- 我有
GLIB
2.31 (Ubuntu GLIBC 2.31-0ubuntu9.2)
我不知道还有什么我可能遗漏或做错的。如有任何帮助,我将不胜感激!
问题自行解决(嗯?)。
- 我添加了 JavaFX
jmod
s 而不是jar
s 并重新编译了 => 没用; - 将 JavaFX 16 (EA) 添加到类路径,然后将其删除 => 它起作用了,很奇怪...