【JavaFX】動画や音声を再生するMediaPlayer

2018年2月17日

本稿は、動画や音声を再生できるMediaPlayerについて紹介したいと思います。

JavaFXには音声を再生することができるAudioClipも存在しますが、アプリケーション自体をJavaFXアプリケーションで作成するのならば、音声再生する用途にもMediaPlayerの使用をお勧めします。

こちらはAudioClipとは違い、メモリに全展開する再生方式ではない為、メモリにやさしい処理となります。

対応ファイル形式に関してはこちらの公式ドキュメントに記述されています。

音声を再生

まずはmp3ファイルの再生から見ていきましょう。

音声の再生はmediaクラスとMediaPlayerクラスを使用します。

JavaFXアプリケーションが終了している状態だと再生されないので注意が必要です。

new Media(ファイルのURI文字列)でインスタンスを作成し

new MediaPlayer(Mediaオブジェクト)と指定しましょう。

使用するサンプルのmp3ファイルは下記
sample2.mp3

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.media.Media;
  5. import javafx.scene.media.MediaPlayer;
  6. import javafx.stage.Stage;
  7.  
  8. public class Test extends Application{
  9.  
  10. public static void main(String[] args) {
  11. launch(args);
  12. }
  13.  
  14. @Override
  15. public void start(Stage primaryStage) {
  16. primaryStage.show();
  17.  
  18. //ファイルを読み込み
  19. Media m = new Media(new File("sample2.mp3").toURI().toString());
  20.  
  21. //音声の再生等の操作を実行できるオブジェクト
  22. MediaPlayer mp = new MediaPlayer(m);
  23.  
  24. //再生開始
  25. mp.play();
  26. }
  27.  
  28. }
実行結果
音声プレーヤー

ウィンドウをあえて表示しているのは、Java9の時点ではJavaFXアプリケーションを実行中の時でなければ再生されないからです。

ゲーム制作においてはどちらにしても表示することになるので問題にはならないでしょう。

動画を再生

動画を再生するにはMediaPlayerをMediaViewに組み込むことで表示できます。

new MediaView(MediaPlayerオブジェクト)と指定しましょう。

動画の再生に使うサンプルは下記です。

※2018/02/17時点でなぜかchrome環境では再生時間が2倍になっています。本当は13秒程度の再生時間です。IE、safari、firefoxでは問題ないようです。chromeのバグか?

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10.  
  11. public class Test extends Application{
  12.  
  13. public static void main(String[] args) {
  14. launch(args);
  15. }
  16.  
  17. @Override
  18. public void start(Stage primaryStage) {
  19. BorderPane p = new BorderPane();
  20. Scene scene = new Scene(p, 800, 600);
  21. primaryStage.setScene(scene);
  22. primaryStage.show();
  23.  
  24. //ファイルを読み込み
  25. Media m = new Media(new File("sample2.mp4").toURI().toString());
  26.  
  27. //動画の再生等の操作を実行できるオブジェクト
  28. MediaPlayer mp = new MediaPlayer(m);
  29.  
  30. //動画パネルの挿入
  31. MediaView view = new MediaView(mp);
  32. p.setCenter(view);
  33.  
  34. //再生開始
  35. mp.play();
  36. }
  37.  
  38. }
実行結果

自動的に再生する時間を指定するsetStartTimeメソッドや準備ができたら即再生するsetAutoPlayメソッドなどの便利なメソッドも存在します。

ループ再生

動画や音声をループ再生させたい場合は

setCycleCount(ループ回数)と指定しましょう。

setCycleCount(MediaPlayer.INDEFINITE)と指定することで無限ループとなります。

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10.  
  11. public class Test extends Application{
  12.  
  13. public static void main(String[] args) {
  14. launch(args);
  15. }
  16.  
  17. @Override
  18. public void start(Stage primaryStage) {
  19. BorderPane p = new BorderPane();
  20. Scene scene = new Scene(p, 800, 600);
  21. primaryStage.setScene(scene);
  22. primaryStage.show();
  23.  
  24. //ファイルを読み込み
  25. Media m = new Media(new File("sample2.mp4").toURI().toString());
  26.  
  27. //動画の再生等の操作を実行できるオブジェクト
  28. MediaPlayer mp = new MediaPlayer(m);
  29.  
  30. //動画パネルの挿入
  31. MediaView view = new MediaView(mp);
  32. p.setCenter(view);
  33.  
  34. //ループ回数を指定
  35. mp.setCycleCount(2);
  36.  
  37. //自動再生開始命令
  38. mp.setAutoPlay(true);
  39. }
  40.  
  41. }
実行結果

サンプルでは2回に設定したので再生終了後もう一度だけ再生されると思います。

停止

再生中の動画や音声を停止したい場合はstopメソッドを使用します。

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10.  
  11. public class Test extends Application{
  12.  
  13. public static void main(String[] args) {
  14. launch(args);
  15. }
  16.  
  17. @Override
  18. public void start(Stage primaryStage) {
  19. BorderPane p = new BorderPane();
  20. Scene scene = new Scene(p, 800, 600);
  21. primaryStage.setScene(scene);
  22. primaryStage.show();
  23.  
  24. //ファイルを読み込み
  25. Media m = new Media(new File("sample2.mp4").toURI().toString());
  26.  
  27. //動画の再生等の操作を実行できるオブジェクト
  28. MediaPlayer mp = new MediaPlayer(m);
  29.  
  30. //動画パネルの挿入
  31. MediaView view = new MediaView(mp);
  32. p.setCenter(view);
  33.  
  34. //自動再生開始命令
  35. mp.setAutoPlay(true);
  36.  
  37. //3秒後に停止命令
  38. new Thread(()->{
  39. try {
  40. Thread.sleep(3000);
  41. } catch (InterruptedException e) {
  42. e.printStackTrace();
  43. }
  44.  
  45. //停止
  46. mp.stop();
  47.  
  48.  
  49. try {
  50. Thread.sleep(3000);
  51.  
  52. //再び最初から再生
  53. mp.play();
  54. } catch (InterruptedException e) {
  55. e.printStackTrace();
  56. }
  57. }).start();
  58. }
  59.  
  60. }
実行結果

今回のような3秒後に停止したい場合などはsetStopTime(new Duration(ミリ秒))で何秒後に停止するかなどを指定したほうが簡単です。

ここではstopメソッドを試したかったのであえてこのようなサンプルとしています。

用途によって使い分けましょう。

まあゲーム用途ならstopメソッドだけ覚えれば問題ないです。

一時停止

pauseメソッドで一時停止ができます。

一時停止後playメソッドを呼ぶと再開できます。

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10.  
  11. public class Test extends Application{
  12.  
  13. public static void main(String[] args) {
  14. launch(args);
  15. }
  16.  
  17. @Override
  18. public void start(Stage primaryStage) {
  19. BorderPane p = new BorderPane();
  20. Scene scene = new Scene(p, 800, 600);
  21. primaryStage.setScene(scene);
  22. primaryStage.show();
  23.  
  24. //ファイルを読み込み
  25. Media m = new Media(new File("sample2.mp4").toURI().toString());
  26.  
  27. //動画の再生等の操作を実行できるオブジェクト
  28. MediaPlayer mp = new MediaPlayer(m);
  29.  
  30. //動画パネルの挿入
  31. MediaView view = new MediaView(mp);
  32. p.setCenter(view);
  33.  
  34. //自動再生開始命令
  35. mp.setAutoPlay(true);
  36.  
  37. //3秒後に一時停止命令
  38. new Thread(()->{
  39. try {
  40. Thread.sleep(3000);
  41. } catch (InterruptedException e) {
  42. e.printStackTrace();
  43. }
  44.  
  45. //一時停止
  46. mp.pause();
  47.  
  48.  
  49. try {
  50. Thread.sleep(3000);
  51.  
  52. //再開
  53. mp.play();
  54. } catch (InterruptedException e) {
  55. e.printStackTrace();
  56. }
  57. }).start();
  58. }
  59.  
  60. }
実行結果

再生位置の指定

seekメソッドを利用します。

seek(new Duration(ミリ秒))で再生位置の指定ができます。

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10. import javafx.util.Duration;
  11.  
  12. public class Test extends Application{
  13.  
  14. public static void main(String[] args) {
  15. launch(args);
  16. }
  17.  
  18. @Override
  19. public void start(Stage primaryStage) {
  20. BorderPane p = new BorderPane();
  21. Scene scene = new Scene(p, 800, 600);
  22. primaryStage.setScene(scene);
  23. primaryStage.show();
  24.  
  25. //ファイルを読み込み
  26. Media m = new Media(new File("sample2.mp4").toURI().toString());
  27.  
  28. //動画の再生等の操作を実行できるオブジェクト
  29. MediaPlayer mp = new MediaPlayer(m);
  30.  
  31. //動画パネルの挿入
  32. MediaView view = new MediaView(mp);
  33. p.setCenter(view);
  34.  
  35. //再生準備完了コールバック
  36. mp.setOnReady(()->{
  37.  
  38. //5秒後から再生開始
  39. mp.seek(new Duration(15000));
  40.  
  41. //再生開始命令
  42. mp.play();
  43. });
  44. }
  45.  
  46. }
実行結果

音量の変更

setVolumeメソッドを利用すると音量を変更できます。

AudioClipとは違い、再生中に音量変更が可能となっています。

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10.  
  11. public class Test extends Application{
  12.  
  13. public static void main(String[] args) {
  14. launch(args);
  15. }
  16.  
  17. @Override
  18. public void start(Stage primaryStage) {
  19. BorderPane p = new BorderPane();
  20. Scene scene = new Scene(p, 800, 600);
  21. primaryStage.setScene(scene);
  22. primaryStage.show();
  23.  
  24. //ファイルを読み込み
  25. Media m = new Media(new File("sample2.mp4").toURI().toString());
  26.  
  27. //動画の再生等の操作を実行できるオブジェクト
  28. MediaPlayer mp = new MediaPlayer(m);
  29.  
  30. //動画パネルの挿入
  31. MediaView view = new MediaView(mp);
  32. p.setCenter(view);
  33.  
  34. //音量のフェードアウト
  35. new Thread(()->{
  36. for ( int i = 100;i >= 0;i-- ) {
  37. mp.setVolume((double)i / 100);
  38. try {
  39. Thread.sleep(100);
  40. } catch ( Exception e ) {
  41. e.printStackTrace();
  42. }
  43. }
  44.  
  45. }).start();
  46.  
  47. //自動再生開始命令
  48. mp.setAutoPlay(true);
  49. }
  50.  
  51. }
実行結果

再生速度の変更

setRate(速度倍率)メソッドを利用すると再生の速度を変更できます。

音声に関してはピッチも変更されます。

  1. import java.io.File;
  2.  
  3. import javafx.application.Application;
  4. import javafx.scene.Scene;
  5. import javafx.scene.layout.BorderPane;
  6. import javafx.scene.media.Media;
  7. import javafx.scene.media.MediaPlayer;
  8. import javafx.scene.media.MediaView;
  9. import javafx.stage.Stage;
  10.  
  11. public class Test extends Application{
  12.  
  13. public static void main(String[] args) {
  14. launch(args);
  15. }
  16.  
  17. @Override
  18. public void start(Stage primaryStage) {
  19. BorderPane p = new BorderPane();
  20. Scene scene = new Scene(p, 800, 600);
  21. primaryStage.setScene(scene);
  22. primaryStage.show();
  23.  
  24. //ファイルを読み込み
  25. Media m = new Media(new File("sample2.mp4").toURI().toString());
  26.  
  27. //動画の再生等の操作を実行できるオブジェクト
  28. MediaPlayer mp = new MediaPlayer(m);
  29.  
  30. //動画パネルの挿入
  31. MediaView view = new MediaView(mp);
  32. p.setCenter(view);
  33.  
  34. //再生速度変更
  35. mp.setRate(2);
  36.  
  37. //自動再生開始命令
  38. mp.setAutoPlay(true);
  39. }
  40.  
  41. }
実行結果

JavaJavaFX

Posted by nompor