簡単な3D×2Dゲームを作ろう
3D×2Dゲーム制作の練習シリーズです。
アンリアルエンジンで3D×2Dゲーム制作方法をまとめていきます。
「2Dゲーム制作の練習シリーズ」で行った説明を省略したり、細かな数値設定などの説明をしない場合もありますので、ご参考程度で確認ください。
※作業環境:UEバージョン5.3.2 Windows11
会話メッセージ表示枠を作成
NPCの会話メッセージを表示する枠を作成していきます。
会話を表示する枠を作成する
まずは枠から作成していきます。
「Blueprints」フォルダー内に「Widgets」ファルダーを作成します。
data:image/s3,"s3://crabby-images/a140f/a140fa9813c643e9705b2d7fc696897f3feadf09" alt=""
「Widget Blueprint」を作成し、ファイル名を「WBP_Speech」にします。
data:image/s3,"s3://crabby-images/1b6b0/1b6b08d32d6e6ff8481eee563a8b7931ce769ef2" alt=""
ファイルを開いて、「Palette」で「Overlay」を検索し、「Hierarchy」に追加します。
data:image/s3,"s3://crabby-images/fbd63/fbd63ef072a00bf1d1f21f2f99709c883c6e2cd7" alt=""
「Border」も追加します。
data:image/s3,"s3://crabby-images/f9202/f9202ec41e3554cbb7e78b2f46555f5952b4852d" alt=""
このとき「Overlay」の中に「Border」を追加します。
「Text」も追加します。
data:image/s3,"s3://crabby-images/a664a/a664a3fe0302e63c5710e7e2af0dcfc1fd4f76f8" alt=""
このとき「Border」の中に「Text」を追加します。
下の写真のように「Fill Screen」を「Desired」に変更します。
data:image/s3,"s3://crabby-images/c1e91/c1e91b8de360b02f76d45dfad6c78f9924ba6fe2" alt=""
「Border」を選択し、設定を変更していきます。
data:image/s3,"s3://crabby-images/bb266/bb26617acbdfa602258052f85cbd4efc96a79d23" alt=""
「Details」の「Content」の「Padding」の値を変更すると、枠の形を変更できます。
data:image/s3,"s3://crabby-images/3c540/3c540a6b185452fd0e99ce83e70a1a14a8fa9363" alt=""
「Appearance」の「Outline Settings」の設定を変更すると、下の写真のような感じにも出来ます。
data:image/s3,"s3://crabby-images/d2e44/d2e4418002340cdf199a2a787835ec494b650892" alt=""
会話枠の背景画像無しで、黒枠の状態だけでも、いい感じで出来ると思います。
今回は「Image」に、表示する枠テクスチャを設定します。
data:image/s3,"s3://crabby-images/a4071/a4071908cf0e2fbda22716c786e1c6e2f7b3cb5d" alt=""
「Text」を選択し、「Details」の「Content」の「Text」で、文章を適当に決めます。
data:image/s3,"s3://crabby-images/80778/80778b52dd846141c4a0fd0a6fb3a5cbe0323eb5" alt=""
最終的に会話メッセージを上書きして使うので、何でも良いです。
「Wrapping」の「Wrap Test At」の値を変更して、メッセージを横幅の限界を決めます。
data:image/s3,"s3://crabby-images/75e11/75e113f98c8654530af46c02a99c800aec2bdd18" alt=""
「Text」の名前を「MessageText」に変更し、「Is Variable」にチェックを入れます。
data:image/s3,"s3://crabby-images/c8ddd/c8dddef32ea0d6fa051752fc702ddedbd9f1b7f0" alt=""
次に、会話しているNPCの名前を表示します。
「Palette」で「Text」を検索し、「Hierarchy」に追加します。
data:image/s3,"s3://crabby-images/c18a1/c18a1090265d7d5f821947c38877b1b80695701d" alt=""
このとき、「Overlay」内に追加するようにします。
追加した「Text」名を「NameText」にし、「Is Variable」にチェックを入れます。
data:image/s3,"s3://crabby-images/4ba19/4ba19325d69e65d6e1aae21a9f7d1ae56d36b62a" alt=""
「Details」の設定で、位置や文字を変更します。
data:image/s3,"s3://crabby-images/b2d9f/b2d9f1a29f303ef6707f30e0cb651cf79ee506fa" alt=""
位置は「Render Transfrom」の項目で変更できます。
会話しているNPCを指すアイコンを作成する
誰が会話しているか分かるように目印を作成していきます。
「Palette」で「Image」を検索して、「Hierarchy」に追加します。
data:image/s3,"s3://crabby-images/255c8/255c8cb23f82fe39aa111e5836b7dcd34197dbbd" alt=""
このとき、「Border」の中に追加します。
追加した「Image」を選択し、「Details」の設定で位置とテクスチャを変更します。
data:image/s3,"s3://crabby-images/c84c6/c84c6853256162a0d12e7d4c9922e685475bdc3b" alt=""
上の写真のように、「Horizontal Alignment」と「Vertical Alignment」を設定すれば、アイコンを真ん中下に移動出来ます。
さらに位置を調整するために、「Render Transfrom」の「Translation」の値を調整します。
data:image/s3,"s3://crabby-images/e98a0/e98a051627ca201b5e35a23982c6894a952f5c01" alt=""
「Color and Opacity」を変更すれば、画像の色や透明度を変更できます。
data:image/s3,"s3://crabby-images/f8330/f8330f4f53be7e7ba719e409c661ea95f40a4676" alt=""
会話中を示すアイコンをアニメーションさせる
会話中、ゲームがフリーズしていないことを示すために、アイコンをアニメーションされます。
これまでと同じ要領で、「Image」を追加して、会話枠の右下に配置し、「Details」の「Tarnsform」の「Angle」で角度を45°傾けます。
data:image/s3,"s3://crabby-images/8f6be/8f6be185a24db5dd91f26e1bc4ead6f7a8f3625b" alt=""
さらに、位置やスケールを調整し、色も変更します。
data:image/s3,"s3://crabby-images/0a09f/0a09f5104d23549c20794bb53df947988b7320b7" alt=""
「Image」を選択した状態で、「Animations」の項目を使って、アニメーションを作成していきます。
data:image/s3,"s3://crabby-images/5cefd/5cefdd172e9121a5a052639a96dcdaef30fd408d" alt=""
「+Animation」をクリックすると、新しいアニメーションを作る項目が追加されるので、「+Track」をクリックし、「Image」を選択します。
data:image/s3,"s3://crabby-images/e5cbe/e5cbebf8fa88fcec91fbd7c987ec0e69700710b8" alt=""
下の写真のように、アニメーションしたい「Image」が追加されたら、その右側にある「+」をクリックして「Transform」を選択します。
data:image/s3,"s3://crabby-images/3bc0c/3bc0cdee15718534bd36448507400ab6a818b8f5" alt=""
これでアニメーションを作成する準備が整いました。
data:image/s3,"s3://crabby-images/1f152/1f152f3cd693d9ec0741763d5a1caaa666978567" alt=""
今回は、上下に移動させながら、回転もするアニメーションを作成します。
まずは回転を設定します。
2.00秒に赤い線を合わせて、「Angle」を「405.0」に設定します。
data:image/s3,"s3://crabby-images/a0c08/a0c0842375a334be5bc84afc3a82a5b57aabdf5a" alt=""
次に上下移動させます。
0.00秒の位置では、現状の位置のままです。
data:image/s3,"s3://crabby-images/be95f/be95f6ee899d3c63a5858900637e1ba9d4a64f36" alt=""
1.00秒では、「Translation」の「Y」の値を「-20.0」にします。
data:image/s3,"s3://crabby-images/8970f/8970f9bf354bc1d348b90e78b7651f4f7094be31" alt=""
2.00秒に位置では「Y」を「0.0」にして、元の位置に戻すようにします。
data:image/s3,"s3://crabby-images/b9521/b952151697d1ef01e351a1e1a7ae42018776f9a8" alt=""
好きな秒数に、設定したい値を入力するだけで、ピン(赤●)は打たれます。
再生ボタン「▷」を押せば、アニメーションを確認できます。
アニメーションが作成できたので、アニメーションを実行させる処理を作成します。
「Graph」画面に移動します。
data:image/s3,"s3://crabby-images/23114/23114e2d66ffb634b66de1f8962bff8b4a2876a1" alt=""
下の写真のように処理を組みます。
data:image/s3,"s3://crabby-images/4295a/4295ac3cf26a12501f4099bf16126411b580b9b1" alt=""
- 「Event Construct」に「Play Animation」ノードを繋げます。
- 「Play Animation」ノードの「In Animation」に、先ほど作成したアニメーションを繋げます。
- 「Num Loops to Play」を「0」にしていれば永久に再生されます。
これで会話枠が表示されたときにアニメーションが実行されるようになりました。
HUDを作成する
HUDを作成し、作成した会話枠を表示していきます。
HUDとは、Head Up Display(ヘッドアップディスプレイ)のことで、画面上に表示されるプレイヤーの情報などを指します。
「Widget Blueprint」を作成して、ファイル名を「WBP_HUD」にします。
data:image/s3,"s3://crabby-images/3ca18/3ca188e8e6cf3e52d19cd41a0ae57abdea81601f" alt=""
ファイルを開いて、「Palette」で「Canvas Panel」を検索し、「Hierarchy」に追加します。
data:image/s3,"s3://crabby-images/7959a/7959a7a9c802a0e0df3b82a5073dd168185d8cb2" alt=""
「Palette」で「WBP Speech」を検索して、追加します。
data:image/s3,"s3://crabby-images/28e86/28e86574a312f3f042129b00e37d8ac49fe4f2b7" alt=""
「WBP Speech」を選択した状態で、「Details」の「Is Variable」にチェックを入れます。
data:image/s3,"s3://crabby-images/6d201/6d20156705e99b7ad0a48c73254781ef04d03d83" alt=""
「Slot」の「Size To Content」にチェックを入れます。
data:image/s3,"s3://crabby-images/4ca47/4ca479aab213858976cf0813a8fd66991b94bac5" alt=""
ゲームモードを設定する
ゲームモードにHUDを表示する処理を追加していきます。
「GM_RPG」を開きます。
data:image/s3,"s3://crabby-images/d8340/d8340904a9e3c3b1720ac111c9e35586822ebebe" alt=""
下の写真のように処理を組みます。
data:image/s3,"s3://crabby-images/3301f/3301f28a9ca8f8f30dc5b992d94d379779ededcd" alt=""
- 「Event BeginPlay」に「Create Widget」ノードを繋げます。
- 「Create Widget」ノードの「Class」を「WBP_HUD」にします。
- 「Create Widget」ノードの結果を変数にして、名前を「HUDWidget」にします。
- 「Add to Viewport」ノードを繋げます。
保存してテストプレイすると、画面上に会話枠が表示されます。
data:image/s3,"s3://crabby-images/59a01/59a01244d61154b92362a7e4441e91787ac1d8bb" alt=""
会話メッセージ表示枠の作成完了
今回はここまでです。
次回は「NPCの頭上にテキストを表示する」です。
前後記事
他の記事を探す
他の記事も気になる方は、以下の記事の目次を確認ください。