CRI Sofdec(Unreal Engine) v1
入門編05 Full Screen再生とUIでのムービー再生の方法(Mana Player編)
この章では、FullScreenやUIでSofdecムービーを再生する方法をご紹介します。
FullScreenでのムービー再生はUMG(Unreal Motion Graphics)を使うことで、画面全体をカバーする画像をUIレイヤーに貼り付けて表示することができます。
具体的な手順は以下のとおりです。
1.Sofdecムービーをインポートして、Manaアセットを準備
「入門編01 Sofdec ムービーの単純再生(Mana Player編)」の手順に従って、フルスクリーン用のムービーをUE5にインポートしてください。
data:image/s3,"s3://crabby-images/6701a/6701a1c7688e66e72209c8f2c64676f1e3694087" alt=""
マテリアルの編集から、マテリアルの"Result Node" を選択します。
詳細パネルで「Material Domain」を"User Interface"に変更してください。
この操作により、ムービーマテリアルがUMGウィジェットで使用できるようになります。
data:image/s3,"s3://crabby-images/c3b7c/c3b7c479abef3a259240b24a6f39006bf74ca5ad" alt=""
注意: 必要に応じて、ManaColorSpaceConverterからの出力を結果ノードのFinal color(アルファムービーが使用されている場合は、不透明度も)に再リンクする必要があります。
2.シーンに新しいUserWidgetブループリントを追加
コンテンツブラウザで新しいブループリントクラスを作成します。
data:image/s3,"s3://crabby-images/d682c/d682cbfb6b1d8cc92a97423df0ec383eba8de4f2" alt=""
"全てのクラス"を展開して、 "Visual/Widget/UserWidget"を選択します。
data:image/s3,"s3://crabby-images/730eb/730ebd0083f20ed3bc5de9ad8d18b5e56123c355" alt=""
作成したアセットの名前を "FullScreenWidget"に変更します。
data:image/s3,"s3://crabby-images/e061c/e061c7ce9f805d0da124d0ee8b311ecb282d44c6" alt=""
3.ウィジェットを編集
「パレット」パネルで「Image」ウィジェットを検索し、デザイナーにドラッグ&ドロップします。
data:image/s3,"s3://crabby-images/345bd/345bd5a6c6e77c3a1a0a8aaaf4b37c38ef03b6e2" alt=""
デザイナーでImage ウィジェットを選択して、詳細パネルで「Appearance/Brush」を展開し、「Image」の欄にムービーマテリアルを設定します。
data:image/s3,"s3://crabby-images/20926/20926be52d9b3e2bd434aafc67d7e160fd1f23ad" alt=""
4.レベルブループリントの編集
レベルブループリントを開きます。 (「ブループリント」ボタン -> 「レベルブループリントを開く...」)
次のブループリントコードを追加してください。
data:image/s3,"s3://crabby-images/25bc0/25bc00cfed237b829523beb0889fa79eb7869ce3" alt=""
こちらからブループリントコードをコピーできます:https://blueprintue.com/blueprint/f4vovdgr/
3つの変数を作成します。
オブジェクトタイプ | 説明 |
Mana (Mana Player オブジェクト参照) | ムービーを再生するためのMana Playerを所有します。 |
Widget (FullScreenWidget オブジェクト参照) | ムービーを表示するためのウィジェットを所有します。 |
data:image/s3,"s3://crabby-images/227e9/227e9a16d7d23c36dd3e9fc7a1a926bc919f5372" alt=""
「Mana Player」ノードの詳細パネルで「Mana」を設定します。
data:image/s3,"s3://crabby-images/ed069/ed069641bd22bd5f827c0002d3b355587ad657ba" alt=""
「Set Texture」ノードの「In Mana Texture」を設定します。
「Open Movie Source」ノードの「In Mana Movie」を設定します。
data:image/s3,"s3://crabby-images/64ff9/64ff98a143a6c2d5385776f42310d900b00d11a9" alt=""
ムービー再生が終了すると、「OnEndReached」イベントが発生するので、その時にFullScreenWidgetを非表示にします。
data:image/s3,"s3://crabby-images/1be77/1be77259dbf256efb03e5ba8092a0f803031b896" alt=""
またこのブループリントでは新たに以下の変数を追加します。
- Is Playing (ブーリアン) 再生ステータスを保持します。
UIでのムービー再生
上述の「Full Screenでのムービー再生」の手順でUIを作成できます。
その後、UMGで必要なUIオブジェクトを追加して、アクションを接続していきます。
ここでは、再生ボタンと停止ボタンを持つUIを例に紹介します。
UIでのムービー再生方法
UIにボタンを追加します。
ウィジェットデザイナー
ブループリントで、「Mana Player」の参照の変数を追加し、ボタンをクリックした時のイベントのコードを追加します。
「Stop」ボタンを押すとMana Pauseが呼び出され、「Play」ボタンを押すとMana ReWindが呼び出されます。
コンテンツブラウザの「追加」->「ユーザーインターフェイス」->「ウィジェットブループリント」を選択してください。
data:image/s3,"s3://crabby-images/b26a4/b26a4b1a622355dc2d04efcdef2c87bd4e554d6d" alt=""
ここでは名前を「UiPlayerWidget」とします。
data:image/s3,"s3://crabby-images/83049/83049afbee1dc4cce55ea2aaa1cd3072bcbd32f9" alt=""
「パネル」->「Canvas Panel」をドラッグ&ドロップします。
data:image/s3,"s3://crabby-images/87a37/87a370d33dc1a16d1ceb3424f1fef8fe1ce86371" alt=""
次に「一般」->「Image」をドラッグ&ドロップします。
data:image/s3,"s3://crabby-images/0e3d6/0e3d64013d7a5264560d184914288836e8cc13ea" alt=""
同様に「一般」->「Button」をドラッグ&ドロップします。
今回は動画の再生と停止を操作する「Stop」と「Play」の2つを用意します。
data:image/s3,"s3://crabby-images/b6579/b6579fab8eb5e5cf9963433eb13f49619ff48415" alt=""
次にボタンに文字を付けます。
「一般」->「テキスト」を配置したボタンの上にドラッグ&ドロップします。
その後「詳細」タブの「コンテンツ」->「Text」で表示する文字を入力します。
data:image/s3,"s3://crabby-images/69088/69088b6072e226e44b6962a1df1fa06fdccfe679" alt=""
次に「階層」からButtonの名前を変更します。「Stop」と「Play」がどちらのボタンかわかる名前であれば構いません。
(今回は「Button_Stop」と「Button_Play」としています)
data:image/s3,"s3://crabby-images/d5e23/d5e2307064b1c1f203714c7c27f7812fb4be96c6" alt=""
ウィジェットブループリント
ユーザーがUIを制御できるように制御モードを設定します。
現在開いている「ウィジェットデザイナー」の右上から「グラフ」を選択します。
data:image/s3,"s3://crabby-images/2b502/2b50281fa249d337f6996b8b902f0b492c7c8dc7" alt=""
レベルブループリント
こちらからブループリントコードをコピーできます。
https://blueprintue.com/blueprint/j_bfoawd/
data:image/s3,"s3://crabby-images/af367/af367fc288da788e348dabffc367bcf865a133ce" alt=""
Unreal Engine マニュアル参照
UMGとアクターコンポーネントの詳細については、Unreal Engineのドキュメントを参照してください。
UMG http://api.unrealengine.com/JPN/Engine/UMG/
Actor Component http://api.unrealengine.com/JPN/Programming/UnrealArchitecture/Actors/Components/