簡単なiPhone向け3Dゲームを作ろう
iPhone向けの3Dゲーム制作の練習シリーズです。
アンリアルエンジンでiPhone向けの3Dゲーム制作方法をまとめていきます。
細かな数値設定などの説明をしない場合もありますので、ご参考程度で確認ください。
※作業環境:UEバージョン5.5.1 Macbook Pro 2019年モデル iPhone11
私の使用したMacの性能だと、作業中の処理落ち、遅延が頻繁に発生しました。
もし同じような端末を使用する場合は、細目に保存することをお勧めします。
ステージの切り替え
今回は、1つ目のステージの特定のポイントに到着したときに、2つ目のステージに切り替えていきます。
転送装置を作成する
プレイヤーをステージ移動させるアクタを作成していきます。
「Content」の「MyGame」フォルダーを開きます。
data:image/s3,"s3://crabby-images/ca6ae/ca6ae44c5c866685ae1c9d4e5f9794f2433330d9" alt=""
右クリックし、「Blueprint Class」を選択します。
data:image/s3,"s3://crabby-images/130a3/130a3d33376d205f498e251355625a330cc76466" alt=""
「Pick Parent Class」画面になるので、「Actor」を選択します。
data:image/s3,"s3://crabby-images/c3376/c3376a9e7aa2e2057af911450c90e983ddcee94d" alt=""
ファイル名を「BP_Teleport」にします。
data:image/s3,"s3://crabby-images/ef5c3/ef5c3f3e83266d31e507601f195d867bbe94837b" alt=""
「BP_Teleport」を開きます。
data:image/s3,"s3://crabby-images/d8356/d8356252cfbfcba40b62067a8d22f2c40e73b500" alt=""
「Components」内の「+ Add」をクリックし、「Sphere」を選択します。
data:image/s3,"s3://crabby-images/0519d/0519dac20605fa8585b1fe7a588cd12e19f428d8" alt=""
「Sphere」を追加できました。
data:image/s3,"s3://crabby-images/d7ba0/d7ba0768f0aca54c66abdcc418a6f08bd251ec12" alt=""
「Details」の「Materials」の「Element 0」を「MirrorPlaneMaterial」に変更します。
data:image/s3,"s3://crabby-images/d9aae/d9aaedf46d08ded529dee953c725c84b0a03120b" alt=""
「MirrorPlaneMaterial」は、「All」の「Engine」の「Content」の「EditorLandscapeResources」のフォルダー内にあります。
data:image/s3,"s3://crabby-images/2fb70/2fb70fa04e580c1f9155a76cf59228fbffaf4356" alt=""
マテリアルを変更した状態は、こんな感じです。
data:image/s3,"s3://crabby-images/eb22c/eb22cc923d1fe81e1773e6c0681f8f60fe87ad23" alt=""
次にテキストも追加していきます。
「Components」の「+ Add」をクリックし、「Text Render」を選択します。
data:image/s3,"s3://crabby-images/89845/89845c73d8e54b07fbdf6659c18471aef6966d28" alt=""
「TextRender」は「Sphere」内に配置します。
data:image/s3,"s3://crabby-images/86b3e/86b3e4e6b98484d61399b9823be1bbd65620496c" alt=""
「TextRender」の位置を調整します。
data:image/s3,"s3://crabby-images/c45ed/c45edb5f909ce9a9ec7b9a211bd5329b79b9c125" alt=""
「Details」の「Text」項目を「Next」に変更します。
data:image/s3,"s3://crabby-images/7c099/7c09990b584620d4d3ad404ac73cc707d062f12b" alt=""
文字の大きさなども変更し、こんな感じにしました。
data:image/s3,"s3://crabby-images/93bd4/93bd457e18c52e3f829939938234c41a1b0d9ecb" alt=""
レベルに配置する
アクタが出来たので、「FirstStage」サブレベルに配置していきます。
レベルを「FirstStage」に切り替えます。
data:image/s3,"s3://crabby-images/da77c/da77c4f1b1253efd7a77d6073f1d406860c1670b" alt=""
ステージの目標地点に、作成した転送装置を配置します。
data:image/s3,"s3://crabby-images/1aee2/1aee23acbebb56aeb5d3af9636ea00beeeb45826" alt=""
配置は出来ましたが、まだステージ切替の処理を実装していないため、ただの障害物になっています。
ステージ切替機能を実装する
転送装置とプレイヤーが重なったときに、ステージを切り替えるよう機能を実装していきます。
「BP_Teleport」を開き、「Details」の「Collision」の「Collision Presets」を確認します。
data:image/s3,"s3://crabby-images/b2878/b2878afa68345909f5506324fdaee72ef168a854" alt=""
「BlockAllDynamic」になっていると、プレイヤーが転送装置を通り抜けできません。
data:image/s3,"s3://crabby-images/5398e/5398e5191b16ecf86eea9279298611b7150ad9a9" alt=""
「OverlapAll」に変更し、通り抜けが出来、何かが重なっていることを通知出来るようにします。
data:image/s3,"s3://crabby-images/310d1/310d150fea8e17c5dd782bd12c5345c8032c66a5" alt=""
次に重なったときの処理を追加していきます。
「Components」の「Sphere」を選択します。
data:image/s3,"s3://crabby-images/a2546/a2546e2ba574bcf83cfa8254721a01818d6e3ec2" alt=""
「Details」の「Events」を確認します。
data:image/s3,"s3://crabby-images/dc2e2/dc2e24682647e20be0dbb77973961318f0442531" alt=""
「On Component Begin Overlap」の横の「+」をクリックします。
data:image/s3,"s3://crabby-images/41141/411414717852137b47d1467a386c5f5b13520b3b" alt=""
「On Component Begin Overlap」ノードが作成されます。
data:image/s3,"s3://crabby-images/4f202/4f2026cc7d71e4271aeaa4908f371e984736ffe0" alt=""
自動的に「Event Graph」に移動しているので、先ほどの画面に戻りたいときは、「Viewport」に切り替えてください。
data:image/s3,"s3://crabby-images/21472/21472e5940e879e63ded67c517cb748a20572936" alt=""
処理を追加していきます。
「On Component Begin Overlap」ノードから「Unload Stream Level (by Name)」ノードを呼び出します。
data:image/s3,"s3://crabby-images/be511/be51142f511d5836a3be2bf5da87f1281e15d563" alt=""
「Unload Stream Level (by Name)」ノードが配置できました。
data:image/s3,"s3://crabby-images/a25cb/a25cb1bd43e092800b579896b9aeda0baa8ead44" alt=""
「Unload Stream Level (by Name)」ノードの「Level Name」を「FirstStage」にします。
data:image/s3,"s3://crabby-images/19ef4/19ef4446c03fddfc325416a14f333aa5f8242639" alt=""
これで1つ目のステージが削除できたので、続いて次のステージをロードします。
「Unload Stream Level (by Name)」ノードから「Load Stream Level (by Name)」ノードを呼び出します。
data:image/s3,"s3://crabby-images/c20ab/c20abab8f6c25a3aa110bce99ebd9b699a060997" alt=""
「Load Stream Level (by Name)」ノードが配置できました。
data:image/s3,"s3://crabby-images/0c495/0c495b58a25934fe76105b32af68159df40cce5a" alt=""
「Load Stream Level (by Name)」ノードの設定を、下の写真のように変更します。
data:image/s3,"s3://crabby-images/1276c/1276ca5faac102fe54c2fd370eccf5b33f452a64" alt=""
これで「NextStage」が表示されるので、次にプレイヤーをスタート位置に移動させます。
下の写真のようにノードを追加します。
data:image/s3,"s3://crabby-images/d53dc/d53dcf4bb2fd3dbfcaf010db89339ace1f5f0c76" alt=""
ここは以下の記事と同じ内容なので説明を省略します。
ノード処理全体はこんな感じになります。
data:image/s3,"s3://crabby-images/072b8/072b846c512e30a38af88b92033c2e17351230fc" alt=""
これで「Compile」すると「FindPlayerStart」ノードに警告が出ます。
data:image/s3,"s3://crabby-images/327af/327afcd80dd823515bba84d5a35f93194a65be74" alt=""
「Target」に「Game Mode Base」が指定されていないので、「Get Game Mode」ノードを追加します。
data:image/s3,"s3://crabby-images/a41ed/a41ed367fa88529a3faa964ed4f45b33762ef29e" alt=""
「Get Game Mode」ノードが配置できました。
data:image/s3,"s3://crabby-images/8d3b9/8d3b95cd0e7c3f776b63bdf070810427d8faada9" alt=""
これで「Compile」しなおすと警告は消えます。
data:image/s3,"s3://crabby-images/a3383/a33835311e7fd4532e2d63d66e650ebf2ba68ea7" alt=""
ここまででテストプレイしてみると、ステージ切替時のプレイヤースタート位置への移動がうまくいかないことがあります。
この問題を解決していきます。
処理を改善する
おそらく「PlayerStart」が複数存在するのが問題の原因と考え、改善を進めます。
レベルを「NextStage」に切り替えます。
data:image/s3,"s3://crabby-images/b83cc/b83cca7ddb553c85346a7161d298795edb6ba906" alt=""
「Outliner」の「PlayerStart」を選択します。
data:image/s3,"s3://crabby-images/506f2/506f2f8b990e707fb309836da401d76f1f5b0d5d" alt=""
「Details」の「Object」の「Player Start Tag」を「player2」に変更します。
data:image/s3,"s3://crabby-images/40f95/40f95128694ea3d54c01978cc4395e0f232f81f1" alt=""
こんな感じです。
data:image/s3,"s3://crabby-images/d2f13/d2f13a9626ce8c9bec0125e39c71c60ee5810093" alt=""
「BP_Teleport」を開きます。
data:image/s3,"s3://crabby-images/e6f10/e6f1054918b5ffb968efc2cfa3105d9765c2bbc5" alt=""
既に配置されている「FindPlayerStart」ノードを見つけます。
data:image/s3,"s3://crabby-images/ee229/ee2292f72d139ad35e00908849b8773ec43b65ad" alt=""
「Incoming Name」を、先ほど設定した「player2」と指定します。
data:image/s3,"s3://crabby-images/7ab54/7ab547cd96a8b69c6ff12baa54513e4550ec4fb1" alt=""
これで、どの「PlayerStart」か判別できるようになりました。
ついでにステージ移動した瞬間、すこしだけプレイヤーの操作を無効にしたいと思います。
「Unload Stream Level (by Name)」ノードを一旦取り除きます。
data:image/s3,"s3://crabby-images/fa866/fa8666b602006e5cded78ec7684ab5a027282d90" alt=""
「Set Actor Transform」ノードの処理の続きに、下の写真の処理を追加します。
data:image/s3,"s3://crabby-images/b6649/b6649ce27f16580c6411687757420801a11557aa" alt=""
- 「Get Player Pawn」ノードと「Get Player Controller」ノードを配置します。
- 「Disable Input」ノードを呼び出して、「Get Player Pawn」ノードと「Get Player Controller」ノードを繋げます。
- 「Set Actor Transform」ノードと「Disable Input」ノードを繋げます。
- 「Disable Input」ノードから「Delay」ノードを呼び出します。
- 「Delay」ノードの「Duration」は「1.0」にしておきます。
ここは操作を無効にしたい間隔を指定すれば良いです。
「Delay」ノードの続きに処理を追加します。
data:image/s3,"s3://crabby-images/03053/030533894d144e6a135029201f1dd8d276e1b7e3" alt=""
- 「Delay」ノードから「Enable Input」ノードを呼び出します。
- 「Get Player Pawn」ノードと「Get Player Controller」ノードを「Enable Input」ノードに繋げます。
- 取り除いていた「Unload Stream Level (by Name)」ノードを「Enable Input」ノードに繋げます。
「Unload Stream Level (by Name)」ノードの設定は、以前のものと同じです。
ノード処理全体はこんな感じになります。
data:image/s3,"s3://crabby-images/0f970/0f9707b706d382bf4244e8c25dc8398eb06f10dc" alt=""
テストプレイして確認します。
data:image/s3,"s3://crabby-images/1e9f4/1e9f4310ba9f776aa628f660d06d16d70023f4e5" alt=""
1つ目のステージの転送装置に触れると2つ目のステージに移動し、1秒ほど待てばプレイヤーを操作できるようになると思います。
ステージ切替完了
今回はここまでです。
次回は「リスポーン設定する」です。
前後記事
他の記事を探す
他の記事も気になる方は、以下の記事の目次を確認ください。