CRI Sofdec(Unreal Engine) v1
入門編06 字幕付きムービーの再生方法
この章では、字幕付きのSofdecムービーを再生する方法を学びます。
字幕付きムービーの再生
下図のように、レベル内のオブジェクトにムービーを貼り付けて再生することが可能です。
具体的な手順は以下のとおりです。
data:image/s3,"s3://crabby-images/a5ba9/a5ba9401ef9eb58140b52faaee0eeaff5077c259" alt=""
1.Sofdecムービーをインポートして、Manaアセットを準備
「入門編01 Sofdec ムービーの単純再生」の手順に従って、字幕付き用のムービーをUE5にインポートしてください。
data:image/s3,"s3://crabby-images/d2e90/d2e90cc44e07b160243b6054091d723421742de0" alt=""
2.レベル内の平面にムービーを貼り付けて、再生する
ManaTextureを保持するためのStaticMeshを作成します。今回の例では平面を使います。
16:9の比率で目に見える位置に設定します。
- 位置:(100.0, 0.0, 110.0)
- 回転:(90.0, 0.0, 90.0)
- 拡大・縮小:(1.777, 1.0, 1.0)
data:image/s3,"s3://crabby-images/fb686/fb686e933a25fa32b8201641adc975d76599bed0" alt=""
コンテンツブラウザを右クリックして「Sofdec」-> 「Mana Player」を選択します。
data:image/s3,"s3://crabby-images/91135/911358fe6911d1053e6e70a5a873d832b34a5797" alt=""
「Video output ManaTexture asset」にチェックを入れて「OK」をクリックします。
これによって「Mana Texture」も同時に作成されます。
data:image/s3,"s3://crabby-images/9138d/9138da3a1d4b9daed698999f3b6e77410cbe1931" alt=""
作成したMana Playerの詳細画面を開き、以下の3項目を設定します。
- 「Play on Open」にチェックを入れる。
- 「Mana Texture」に先ほどMana Player作成時に同時作成したMana Textureを選択する。
- 「Mana Movie」に字幕付き用のムービーを選択する。
コンテンツブラウザのMana Textureを右クリックしてCreate Materialを選択し、マテリアルを作成します。
data:image/s3,"s3://crabby-images/7c39d/7c39d1c54044e72b85accaa7d587a3cb82e09ece" alt=""
レベルに配置したPlaneの詳細から、マテリアルを先ほど作成したマテリアルに設定します。
data:image/s3,"s3://crabby-images/2989e/2989e79449bf289bc8a75c0664c49677d0945b61" alt=""
以上の操作で平面上でムービーが再生されるようになります。
3.ムービー再生に字幕を追加
「コンポーネントを追加」ドロップダウンリストから、「TextRender」を選びます。
data:image/s3,"s3://crabby-images/5ea89/5ea8938116ab657fc71c589272ae9bcf9c5ecb50" alt=""
ビューポートでプレーン上で見える位置にTextRenderを配置します。
data:image/s3,"s3://crabby-images/65ac8/65ac837f22b45cc9141dd2cd8e9ea7a810a55a82" alt=""
コンポーネントリストでManaを選びます。
data:image/s3,"s3://crabby-images/27edc/27edc2c112b5f38ee5b0e1f151c81935976944b3" alt=""
字幕付きのムービー再生をするために、Manaの詳細パネルの「Subtitle」セクションを編集します。
- 「Subtitles Enable」をオンにして字幕を有効化します。
- 「Subtitles Channel」を設定します。
- 字幕チャンネルに使用した文字列エンコーディング「Subtitles Encoding」を選択します。(デフォルトはutf-8です。)
data:image/s3,"s3://crabby-images/1e070/1e070e9551cd8dbf2e4461a7d4b335d88d139ea6" alt=""
"OnSubtitlesChanged"イベントを登録してください。
イベントがトリガーされたら、新しい字幕を取得し、TextRenderで表示するテキストを変更します。
data:image/s3,"s3://crabby-images/cb997/cb997bbe00f8640e662fcfb2d46734ce01691853" alt=""
こちらからブループリントコードをコピーできます:https://blueprintue.com/blueprint/wp821pfq/
data:image/s3,"s3://crabby-images/3e0d0/3e0d0d6293768dfec7118ba3dcd4edcdd4b6e8a3" alt=""
ムービーの字幕をゲーム画面上に表示する
1.シーンに新しいUserWidgetブループリントを追加
コンテンツブラウザで新しいブループリントクラスを作成します。
data:image/s3,"s3://crabby-images/8d23f/8d23f86f56f2eac9c680b7b7da05991dbbf4b504" alt=""
"全クラス"を展開して、 "Visual/Widget/UserWidget"を選択します。
data:image/s3,"s3://crabby-images/c7302/c730287b6ef716327069f99e7e686f4133905d2f" alt=""
新しいアセットの名前を "SubtitleWidget"に変更します。
data:image/s3,"s3://crabby-images/d7547/d7547cb252d797e2710c7ba3e47d6041317e0cfc" alt=""
2.ウィジェットのデザイナーでテキストブロックウィジェットを追加
デザイナーで「パネル」の「Canvas Panel」を追加します。
data:image/s3,"s3://crabby-images/e4648/e464800953f09786edc1d30890be46eb2168db11" alt=""
「一般」の「Text」を追加します。
テキストブロックをキャンバスに入れて、サイズを調整します。
黒のアウトラインで正式な字幕を表示するには、テキストブロックの詳細で、アンカー、フォントのサイズ、「Outline Settings」(サイズ、色など)のようないくつかのパラメータを調整します。
字幕を複数行に表示するには、「Auto Wrap Text」を有効にします。
また、テキストウィジェットを変数「Is Variable」に設定して、他のブループリントにアクセスできるようにします。
data:image/s3,"s3://crabby-images/25da1/25da116b97d7efc160556afc47b022f2d95e22ce" alt=""
data:image/s3,"s3://crabby-images/457aa/457aa248c8ee42c9a7d1936bf056b48cf24bf879" alt=""
3.ブループリントを更新
1つの変数を追加します。
Widget (SubtitleWidget オブジェクト参照) : 画面でテキストを見せるためのウィジェットを所有します。
data:image/s3,"s3://crabby-images/bf5da/bf5da6bbf330bea47d1a56be49da4cff59c08c3b" alt=""
前のセッションで作成したブループリントで、ウィジェットのテキストブロックに字幕テキストを送信するようにブループリントを変更します。
data:image/s3,"s3://crabby-images/23ad3/23ad3216592880739f038bff9c6cf118919ef989" alt=""
こちらからブループリントコードをコピーできます:https://blueprintue.com/blueprint/tsyxnafa/
「入門編05 Full Screen再生とUIでのムービー再生の方法」と組み合わせることで、UIで字幕付きのフルスクリーンムービーを再生することができます。
Unreal Engine マニュアル参照
アクターコンポーネントとUMGの詳細については、Unreal Engineのドキュメントを参照してください。
Actor Component http://api.unrealengine.com/JPN/Programming/UnrealArchitecture/Actors/Components/
UMG http://api.unrealengine.com/JPN/Engine/UMG/
TextRender (API) https://api.unrealengine.com/INT/BlueprintAPI/Rendering/Components/TextRender/index.html