【问题标题】:Debian Jessie JavaFX MediaPlayer : Could not create playerDebian Jessie JavaFX MediaPlayer:无法创建播放器
【发布时间】:2016-03-08 12:55:07
【问题描述】:

我在运行具有 Ant 配置的 java 应用程序时遇到此异常。

Exception in thread "JavaFX Application Thread" MediaException: UNKNOWN : com.sun.media.jfxmedia.MediaException: Could not create player! : com.sun.media.jfxmedia.MediaException: Could not create player!

这是我的代码:

@Override public void start(Stage stage) {
    final Scene scene = new Scene(((Viewer)viewer).getPanel());
    Media theme = new Media(getHostServices().getDocumentBase() + "src/sound/theme_bttf.mp3");
    new MediaPlayer(theme).play();
}

有人对如何解决这个问题有想法吗?

我使用 Gnome 3.14.1JavaDebian Jessie 64bits 上运行它:

java version "1.8.0_74"
Java(TM) SE Runtime Environment (build 1.8.0_74-b02)
Java HotSpot(TM) 64-Bit Server VM (build 25.74-b02, mixed mode)

编辑:

这是我在执行ant run 时得到的堆栈跟踪:

run:
 [echo] ================ Run Object Main ================
 [java] Gtk-Message: Failed to load module "canberra-gtk-module"
 [java] Exception in Application start method
 [java] java.lang.reflect.InvocationTargetException
 [java]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 [java]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 [java]     at java.lang.reflect.Method.invoke(Method.java:498)
 [java]     at com.sun.javafx.application.LauncherImpl.launchApplicationWithArgs(LauncherImpl.java:389)
 [java]     at com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:328)
 [java]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
 [java]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
 [java]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
 [java]     at java.lang.reflect.Method.invoke(Method.java:498)
 [java]     at sun.launcher.LauncherHelper$FXHelper.main(LauncherHelper.java:767)
 [java] Caused by: java.lang.RuntimeException: Exception in Application start method
 [java]     at com.sun.javafx.application.LauncherImpl.launchApplication1(LauncherImpl.java:917)
 [java]     at com.sun.javafx.application.LauncherImpl.lambda$launchApplication$155(LauncherImpl.java:182)
 [java]     at java.lang.Thread.run(Thread.java:745)
 [java] Caused by: MediaException: UNKNOWN : com.sun.media.jfxmedia.MediaException: Could not create player! : com.sun.media.jfxmedia.MediaException: Could not create player!
 [java]     at javafx.scene.media.MediaException.exceptionToMediaException(MediaException.java:146)
 [java]     at javafx.scene.media.MediaPlayer.init(MediaPlayer.java:511)
 [java]     at javafx.scene.media.MediaPlayer.<init>(MediaPlayer.java:414)
 [java]     at alpha.Main.start(Main.java:71)
 [java]     at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$162(LauncherImpl.java:863)
 [java]     at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$175(PlatformImpl.java:326)
 [java]     at com.sun.javafx.application.PlatformImpl.lambda$null$173(PlatformImpl.java:295)
 [java]     at java.security.AccessController.doPrivileged(Native Method)
 [java]     at com.sun.javafx.application.PlatformImpl.lambda$runLater$174(PlatformImpl.java:294)
 [java]     at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
 [java]     at com.sun.glass.ui.gtk.GtkApplication._runLoop(Native Method)
 [java]     at com.sun.glass.ui.gtk.GtkApplication.lambda$null$49(GtkApplication.java:139)
 [java]     ... 1 more
 [java] Caused by: com.sun.media.jfxmedia.MediaException: Could not create player!
 [java]     at com.sun.media.jfxmediaimpl.NativeMediaManager.getPlayer(NativeMediaManager.java:274)
 [java]     at com.sun.media.jfxmedia.MediaManager.getPlayer(MediaManager.java:118)
 [java]     at javafx.scene.media.MediaPlayer.init(MediaPlayer.java:467)
 [java]     ... 11 more
 [java] Exception running application alpha.Main
 [java] Java Result: 1

编辑 2:

我安装了libavcodec56libavformat56 和 GLIB 2.42.1。

# pkg-config --modversion glib-2.0
2.42.1

【问题讨论】:

  • 请向我们展示完整的堆栈跟踪。
  • @Puce 刚刚在我的帖子中添加了堆栈跟踪

标签: java javafx debian


【解决方案1】:

来自Certified System Configurations http://www.oracle.com/technetwork/java/javase/downloads/index.html部分

您必须安装 GLIB 2.28 才能运行 JavaFX Media。

您必须安装以下内容才能支持 AAC 音频、MP3 音频、H.264 视频和 HTTP 实时流媒体:

  • Ubuntu Linux 12.04 或同等版本上的 libavcodec53 和 libavformat53。

[...]

  • VP6 视频支持不需要任何第三方模块。
  • 在 Linux 平台上,安装 libavformat 会自动导致安装 libavcodec。

请仔细检查您是否安装了所有必需的库。

【讨论】:

  • @Senorihl 我猜你也安装了 GLIB 2.28?
  • 我猜......我可以用什么名字来搭配 aptitude ?
  • 并安装了 GLIB 2.42.1
  • @Senorihl 如果您认为您已正确设置所有内容,但仍然出现错误,请在此处提交问题:bugs.java.com
【解决方案2】:

虽然Media 的构造函数的参数是String,但它必须格式化为有效的URI。所以而不是:

Media theme = new Media(getHostServices().getDocumentBase() + "src/sound/theme_bttf.mp3");

试试这个:

Media theme = new Media(new File(getHostServices().getDocumentBase() + "src/sound/theme_bttf.mp3").toUri().toString());

【讨论】:

    【解决方案3】:

    在这种情况下存在一个 java 错误。尝试下载已修复的新版本(我下载了jdk 8u102)。 http://www.oracle.com/technetwork/pt/java/javase/downloads/jdk8-downloads-2133151.html

    【讨论】:

      猜你喜欢
      • 2014-07-28
      • 2020-03-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2017-10-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多