レベル内でビデオをプレイする

メディア内でビデオをプレイするための File Media アセットの使用方法を説明します

コンテンツ

レベル内でビデオをプレイするには、Media Framework ツールと Media Source アセットを使わなければなりません。レベル内の TV 上でプレイする場合、UI の一部としてのバックグラウンドでプレイする場合、または全画面でプレイする場合でも必要になります。 Media Source アセットにはさまざまな種類がある一方で、デバイス (たとえばコンピュータ、電話、コンソール) 上に Unreal Engine 5 (UE5) でプレイしたいビデオ ファイルを格納している時は File Media Source アセットが使用されます。

この操作ガイドでは、Media Source アセットを使ってレベル内のスタティックメッシュ上でビデオをプレイします。

このチュートリアルでは、動画ファイルを再生するための手動ワークフローを説明します。5.1 以降では、メディアソースをドラッグ&ドロップで追加できる Media Plate Actorや、事前に作成されたメッシュに最適化されたストリーミングを使用することもできます。

MediaHero.png

ステップ

ここでは Starter Content Enabled (スターター コンテンツを有効にした状態)Blueprint Third Person Template プロジェクトを使います。 再生するコンピュータ上に サポートされているビデオ ファイル がいくつか必要です。自分のビデオを使用できます。ビデオがない場合は、チュートリアル用の サンプル ビデオ を右クリックでダウンロードすることができます。

  1. [コンテンツ ブラウザ][Sources Panel] を展開したら、[Content]「Movies」 という名前のフォルダを作成します。

    01-new-folder-movies.png

    プロジェクトの 「Content/Movies」 フォルダ内に使用するメディア ファイルを置くと、メディアが確実にプロジェクトで正しくパッケージ化されます

  2. 「Movies」 フォルダを 右クリック して [Show in Explorer (エクスプローラーで表示)] を選択します。

    02-show-in-folder.png

  3. 使用するビデオ ファイルをプロジェクトの 「Content/Movies」 フォルダにドラッグします。

    03-folder-video.png

    ビデオ コンテンツをプロジェクトでパッケージ化およびデプロイするために、コンテンツは常にプロジェクトの 「Content/Movies」 フォルダに置かれている状態にしておく必要があります。

  4. プロジェクト内の 「Movies」 フォルダを 右クリック して、[Media][File Media Source] を選択し、SampleVideo というアセットを呼び出します。

    04-file-media-source.png

  5. File Media Source アセットの File Path[...] ボタンをクリックして、コンピューター上にあるサンプ ビデオを指定します。

    Click image to expand.

  6. 「Movies」 フォルダを右クリックして [Media] から [Media Player] を選択します。

    06-media-player.png

  7. [Create Media Player] ウィンドウで [Video output Media Texture asset] オプションを有効にして [OK] ボタンをクリックします。

    07-video-output-asset.png

    すると、 Media Texture アセットが作成され、作成中の Media Player に自動的に割り当てます。Media Texture はメディア コンテンツの再生を行い、これを使ってレベル内のスタティックメッシュへの割り当てが可能な Material を作成することができます (本ページのもう少し後の方で出てきます)。

  8. Media Player と Media Texture asset にそれぞれ MyPlayerMyPlayer_Video と名前を付けてから MyPlayer Media Player アセットを開きます。

    Click image to expand.

  9. [Media Library] セクションの SampleVideo をダブルクリックします。

    Click image to expand.

    [Media Library] セクションで File Media Source アセットをダブルクリックすると、ビデオの再生が始まります。これは、[Details] パネルの [Playback] セクションの [Play on Open] オプションが有効にされているからです。 このオプションにチェックが付いていると、Media Source アセットが開く時は必ず自動再生が始まるので、プレイの開始を明示的に指示する必要はありません。

    もう少し後のステップになりますが、メディア エディタ内でビデオが再生されている間に、ゲームのプレイ中にファイルのプレイが開始するように、ゲーム中に Media Source アセットを開くように ブループリント ビジュアル スクリプティング を使ってメディア プレイヤーに指示する必要があります。

  10. メイン エディタの [Place Actors] パネルの [Basic] タグから[Plane] をレベルにドラッグし、Transform ツールを使って自由にサイズ変更および配置します。

    Click image to expand.

    レベルでその Plane を選択した状態で、Transform ツール を使ってメッシュを Translate (W)Rotate (E)Scale (R) して、好きな外観に調整します。

  11. MyPlayer_Video Media Texture アセットをレベルの Plane 上にドラッグして Material を自動作成および割り当てをします。

    Click image to expand.

    Media Texture をレベルのスタティックメッシュ上にドラッグすると、コンテンツ ブラウザ 内に自動的に新規マテリアルが自動作成され、レベルのメッシュに適用されます。

  12. レベルでその Plane を選択した状態で [Details] パネルの [Add Component] ボタンをクリックして Media Sound を探して追加します。

    12-media-sound.png

    Media Sound コンポーネントを使って、ビデオと一緒に再生するオーディオを定義します。

  13. [Details] パネルで新しい Media Sound コンポーネントを [Media] セクションから選択し [Media Player]MyPlayer を使う設定にします。

    Click image to expand.

    ここで Media Sound コンポーネントを Media Player アセットに関連付けて、オーディオの抽出元が分かるようにします。

  14. メインツールバーの [Blueprints] ボタンをクリックして [Open Level Blueprint] を選択します。

    14-open-level-blueprint.png

    Level Blueprint を使って Media Player に File Media Source アセットをゲームプレイの開始時に開いてレベルでゲームが開始されるように設定します。

  15. Media Player Reference 型の MediaPlayer という Variable を追加し、[Default Value]MyPlayer に設定します。

    Click image to expand.

    Default Value を定義するために、[Compile] ボタンの作成が必要な場合があります。

  16. Ctrl キーを押しながら MediaPlayer をグラフにドラッグし、グラフを右クリックして Event Begin Play ノードを検索して追加します。

    Click image to expand.

    ゲームプレイの開始を知らせるためのノードと Media Player アセットへの参照ができました。あとは、プレイヤーに Media Source を開く指示を出すだけです。

  17. Media Player ノードをクリックして引き出し Open Source 機能の Media SourceSampleVideo に設定して Event Begin Play に接続します。

    Click image to expand.

  18. Level ブループリント を終了して、[Play in Editor] ボタンをクリックします。

最終結果

エディタで再生した場合、スタティックメッシュ上でビデオがプレイを開始します。

Media Player アセットはデフォルトで [Play on Open] に設定されているため、Open Source 関数を呼び出すとビデオが自動的に開始されます。 一時停止、巻き戻り、ビデオの停止など Media Player アセットに発行できるコマンドは他にもあります。プレイが開始されると Media Player Reference を引き出す時に、Media Player セクションに表示されます。

この例では、プロジェクトの 「Content/Movies」 フォルダ内にメディア コンテンツを置くようにしました。このフォルダはコンテンツをパッケージ化 / デプロイ処理の一部としてコンテンツを自動的に含む唯一のフォルダなので、プロジェクトをパッケージ化する場合は推奨します (必須ではありません)。 File Media Source アセットをこの場所以外のフォルダに指定してもメディアはプレイされますが、たとえばモバイル デバイスにデプロイすると、コンテンツはデプロイメントの一部として含まれなくなります。

Unreal Engine のドキュメントを改善するために協力をお願いします!どのような改善を望んでいるかご意見をお聞かせください。
調査に参加する
キャンセル