簡単な3D×2Dゲームを作ろう
3D×2Dゲーム制作の練習シリーズです。
アンリアルエンジンで3D×2Dゲーム制作方法をまとめていきます。
「2Dゲーム制作の練習シリーズ」で行った説明を省略したり、細かな数値設定などの説明をしない場合もありますので、ご参考程度で確認ください。
※作業環境:UEバージョン5.3.2 Windows11
会話を続けて表示
1文で入りきらない会話を分割します。
ボタンを押すと、次の文を表示するようにしていきます。
会話内容データを作成する
会話の文章をまとめたデータを作成していきます。
「Content」に「DataTables」フォルダーを作成します。
data:image/s3,"s3://crabby-images/46ba2/46ba208e0c9d5a892c477bdfd718d7f71c74961b" alt=""
フォルダー内で右クリックして、「Blueprint」の「Structure」を選択します。
data:image/s3,"s3://crabby-images/9caa7/9caa73246e943151abf2fc45b2e555fc64059f3c" alt=""
ファイル名を「S_DialogueData」にします。
data:image/s3,"s3://crabby-images/3aafc/3aafc5d61604d8749966eea299c6d5e0329d030c" alt=""
ファイルを開いて、「+Add Variable」をクリックし、要素を追加します。
data:image/s3,"s3://crabby-images/4ae8c/4ae8c92ea41ed609447dbaaefbbb32d3f14b516e" alt=""
下の写真のように、「DialogueText」と「NextRow」を追加し、どちらも「String」型にします。
data:image/s3,"s3://crabby-images/cc5d7/cc5d7358860c048fa89de3c3502bc7b83c7e1cbe" alt=""
「DataTables」フォルダー内で右クリックして、「Miscellaneous」の「Data Table」を選択します。
data:image/s3,"s3://crabby-images/34477/344776b997f2edec41cb8d02b4bbe7fe53007701" alt=""
「Pick Row Structure」画面になるので、「None」を「S_DialogueData」にして、ファイルを作成します。
data:image/s3,"s3://crabby-images/a1d28/a1d28102848ad94acdfe801949c14b0c5da101e5" alt=""
ファイル名は「DT_Dialogue」にします。
data:image/s3,"s3://crabby-images/9959f/9959f6b0c0b08cf263de388d402764322cf7ab1a" alt=""
ファイルを開いて、「+Add」をクリックし、項目を追加します。
data:image/s3,"s3://crabby-images/559bc/559bc963afc6c88c5c6136e54a0f6216b83adba6" alt=""
下の写真のように、データを入力します。
data:image/s3,"s3://crabby-images/269e7/269e7f15d45ecfa184d707cd641231685e7d2603" alt=""
各項目は「Row Editor」内で入力できます。
会話内容をスプレッドシートで管理する方法もあります。
以下の記事を参考にしてください。
作成したデータを適用する
会話内容を作成できたので、これを会話ボタンを押したときの処理に適用していきます。
「BP_CharacterBase」を開きます。
data:image/s3,"s3://crabby-images/02e26/02e26414e4612f0b2a1ecf41b909a0d570e19e70" alt=""
「Show Dialogur Line」関数を開きます。
data:image/s3,"s3://crabby-images/9ef88/9ef881b73f8c1bf872e18d68cac7411c308bab4a" alt=""
「Show Dialogur Line」の続きに、「Get Data Table Row」ノードを配置します。
data:image/s3,"s3://crabby-images/e65e5/e65e569ae92c3846356fd0e78eebcae5dde30593" alt=""
Inputピンの、「Data Table」には「DT_Dialogue」を設定し、「Row Name」には「NPC_Messege」を設定します。
data:image/s3,"s3://crabby-images/58d22/58d2200be0a5643a89fa9e26178f913a2f496c94" alt=""
「Get Data Table Row」ノードの「Out Row」から「Break S_DialogueData」を呼び出し、「Dialogue Text」を「Show Dialogue」に繋げます。
data:image/s3,"s3://crabby-images/f3cea/f3ceacb00b1c73a2bb1a0b54c1ad83aa192e6095" alt=""
これにより、出力された「Row Name」のデータ内容を分割して、テキストだけを使うことが出来ます。
「Row Name」の値はNPCごとに変更したいので、「Get Data Table Row」の「Row Name」を変数化します。
data:image/s3,"s3://crabby-images/60413/60413c83b827304d8f236edd8f680345e71e3fc7" alt=""
「Row Name」を選択した状態で、「Details」の「Default Value」の値を「NPC_Messege」にします。
data:image/s3,"s3://crabby-images/8a283/8a28359e022acfeb198c851f6b96e20a19ef3375" alt=""
レベルに配置しているNPCを選択し、「Details」の「Row Name」を確認すると、先ほど設定した値が入力されています。
data:image/s3,"s3://crabby-images/fb33b/fb33bb7a0af1731c53fdf346f6020ed4f258be4b" alt=""
試しに「NPC_Messege_1」を入力します。
data:image/s3,"s3://crabby-images/598b1/598b165e23e78086a92d58cd55a6895831eb1db7" alt=""
テストプレイすると、メッセージが変わっていることが確認できます。
data:image/s3,"s3://crabby-images/3db53/3db53f66d10422363e65bd00d4cbb1017a16711d" alt=""
確認出来たら「NPC_Messege」に戻しておきます。
会話テキストを続けて表示する
設定した会話テキストを、続けて表示するようにしていきます。
「BPI_Interaction」を開きます。
data:image/s3,"s3://crabby-images/97dd5/97dd56115e95e4211c04126947a2f1dd33a058b8" alt=""
「FUNCTIONS」の右にある「+」をクリックして、関数を追加し、関数名を「NextText」にします。
「NextText」を選択した状態で、「Outputs」の右にある「+」をクリックして、要素を追加し、「Boolean」型の「IsNextText」を作成します。
data:image/s3,"s3://crabby-images/7cab8/7cab8db0021e8550232d433a8388363010f440b8" alt=""
「BP_Player」を開きます。
data:image/s3,"s3://crabby-images/c84f9/c84f998089526236a7a265f93765fbb77b9c1678" alt=""
会話ボタンの処理の場所に移動します。
data:image/s3,"s3://crabby-images/70768/7076866d37c566fdc0db9c69a748434c38ee0a3a" alt=""
「Branch」ノードの「True」側の分岐に、下の写真のように処理を追加します。
data:image/s3,"s3://crabby-images/fc3fb/fc3fbfe2fc9a1222438e9dcf8d6e4dcf491e76b8" alt=""
- 「Last Interacted」をゲットし、「Next Text」関数と繋げます。
- 「Next Text」関数の結果と「Branch」ノードを繋げます。
- 「Branch」ノードの「False」側に続きの処理を繋げます。
ここでは、会話に続きがあるか確認して、なければ会話を終わらせるようにしています。
「BP_CharacterBase」を開きます。
data:image/s3,"s3://crabby-images/02e26/02e26414e4612f0b2a1ecf41b909a0d570e19e70" alt=""
「Show Dialogur Line」関数を開いて、下の写真のように処理を追加します。
data:image/s3,"s3://crabby-images/99489/99489a0ffabfde14b2d891af8c296d77770572a3" alt=""
- 「Break S_DialogueData」の「Next Row」を変数化します。
- 「Show Dialogue」の続きに「SET」ノードを配置します。
「INTERFACES」の「Next Text」をダブルクリックします。
data:image/s3,"s3://crabby-images/d9182/d91822eab550031912102db54b235e1437f4d6d4" alt=""
下の写真のような画面に切り替わります。
data:image/s3,"s3://crabby-images/a606d/a606d5cec0c502f4d121980e83b599f1bc1c892d" alt=""
下の写真のように処理を追加します。
data:image/s3,"s3://crabby-images/cba44/cba44cc4914015fd7ca896775459c5c08a8fc0d0" alt=""
- 「Branch」ノードを配置し、「True」側には「Return Node」を繋げます。
- こちら「Return Node」の「Is Next Text」のチェックは外します。
- 「Next Row」をゲットして、「Is Empty」ノードを繋げ、その結果を「Branch」ノードの「Condition」に繋げます。
- 「Branch」ノードの「False」側に「Row Name」をセットします。
- 「Next Row」をゲットし、「Row Name」に繋げます。
- 繋げると自動で型変換ノードが配置されます。
- 「Row Name」の続きに「Show Dialogur Line」関数を繋げます。
- 「Return Node」を配置して、「Show Dialogur Line」と繋げます。
- こちらの「Return Node」には「Is Next Text」にチェックを入れます。
これで、会話テキストに続きがあるかどうかを確認できるようになりました。
会話テキストをリセットする
会話終了後にもう一度話しかけると、2個目のテキストが表示されます。
1個目のテキストから表示するようにします。
「BP_CharacterBase」の「Event BeginePlay」の処理を確認します。
data:image/s3,"s3://crabby-images/80f44/80f4499305fd7b0a2b5de343b423ead8cf863e47" alt=""
新しく変数を作成し、変数名は「Reset Row Name」、型は「Name」にします。
「Set Cast Shadow」の続きに、「Reset Row Name」をセットして、「Row Name」をゲットし繋げます。
data:image/s3,"s3://crabby-images/78cd4/78cd4293a88186622b10f2e7974fc4a5f86e59da" alt=""
ここでは、NPCが生成されたときに、初期の「Row Name」設定を保管しています。
「Next Text」関数を開いて、下の写真のように処理を追加します。
data:image/s3,"s3://crabby-images/5947a/5947a45e26a23d96281760a9d4de32a84a8cc302" alt=""
- 「Branch」ノードの「True」側の分岐に、「Row Name」をセットします。
- 「Row Name」に「Reset Row Name」を繋げます。
ここで、保管していたデータをセットして、会話が終わったら初期状態に戻しています。
設定完了したので、テストプレイします。
data:image/s3,"s3://crabby-images/79f91/79f9175f83cb7f95fe3c7a0a8cc34a93ac4751e8" alt=""
1度会話が終わった後に、再度NPCに話しかけると、初めのテキストから表示されます。
ここまで出来たら、以下の記事の内容も取り入れてみてください。
3D×2Dゲーム制作練習終了
ここまで読んでいただき、ありがとうございます!
今回の記事で、このシリーズは完結となります。
ゲームとしては会話と探索しか出来ないものになっていますが、3Dと2Dを組み合わせたゲームを作るための1歩にはなったかなと思います。
当サイトでは、Unreal Engineを使ったゲーム開発における疑問点や、問題解決などを投稿しています。
すこしでも悩み解決の糸口になれば幸いです。
これからも、より良いゲーム開発ライフをお過ごしください!
前後記事
他の記事を探す
他の記事も気になる方は、以下の記事の目次を確認ください。