5
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

UE4でOculusQuest2を動かす3

Last updated at Posted at 2022-02-17

初めに

 本記事は前回の続きですので、できれば前回をご覧ください。また、この記事を書いている人は、VR開発については全くの初心者で、普通に間違っている可能性も十分にあるので、その点に関してはご了承ください。

ゲーム部分

 ゲーム部分については簡単に記述します。というのも、中身自体がとてつもなく簡単なゲームのようなものなので、記述する内容があまりな...ではなくVR自体にはあまり関係ないからですね。
 ゲームを一言で言うなら「敵UFOを打ち落とす360°シューティング」です。詳細は前回の記事をご覧ください。
サンプルゲーム.png
 自機は中心・敵は周囲に沸いて打ち落とそうとしている図 ↑

自機/敵UFOの作成・スポーン

・作成

 自機には前回作成した方法で作成します。下図のSkeletalMeshL/Rに関しては、色々やろうとして結局やめた残骸なので気にしないで下さい。それと、WidgetInteractionL/RLaserL/Rは後述するUIに使用します。
自機 コンポーネント.png
 次に、自機から弾を発射する為に砲台アクターを作成します。イメージとしては砲台を遠隔操作するイメージです。アクターは半透明のメッシュを使用して、レーザーサイト的なものをしておくと、撃つ方向がかなり分かりやすくなると思います。
自機 砲台.png
 実は、砲台の回転に「実際の手の動き」を適用するか迷ったりしたのですが、せっかく実装したVRっぽい動きなので実装する事にしました。
自機 砲台 動き.gif


 敵に関してはStatic MeshSphere Collisionを追加しただけのシンプルなアクターです。簡易的な軽量化の為ですね。といっても、ガチガチに軽量化するならばインスタンシング描画を使ったり、当たり判定をメインスレッドから切り離したりするといった手段を考えられますね。
敵機.png

・スポーン

 Player Startは適当な部分に設置して、ワールドセッティングで作成した自機を設定します。そして、敵UFOに関してはプレイヤーを中心にスポーンさせます。
 スポーンさせる時はRandom Rotatorを使ってランダムな角度を取得、Clamp Angleでピッチ方向に制限をかけ、自機を中心にランダムな距離を設定するだけの簡単なお仕事です。以上、Random Rotatorを紹介したかっただけでした1
敵スポーン1.png
 ピッチ方向に制限をかけているのは、真下/上方向に出現するのは流石に狙いずらいからです。それと、Enm Assetに関しては「データアセット」を使用したものになっています。「データアセット」に関しては今回は紹介しませんが、次の記事ぐらいに詳細を紹介したいと思います。

ゲームシステム

 後は簡単でプレイヤーのHPが0になるまで永遠に続きます。今回は簡易的な実装なので、敵は一定間隔でスポーンするようにしていますが、徐々に間隔を短くしていったり、敵UFOの速度を上げたりするなど色々考えられます。

もっとゲームらしくするなら?

 敵の種類を増やしたり、自機の発射システムを変更したり(追跡弾・レーザーなど)、「頑張れば」もっと面白く出来ますね。今回は実装しませんが...。

VRのUI

 VRの難しい部分「UI」についてです。下記サイトによると、通常のゲームで使用するUIは使えないみたいですね。

VR上ではその仕組み上、2DのUIを扱うことはできません。常に正面に配置するためには3D UIを配置し、カメラの向きに合わせて正面を向かせる必要がありますが、これはVR上で酔いを発生させる要因となりやすいので、オススメできません。
https://forums.unrealengine.com/t/vr-ui/456821

 つまり、VRになるとUIがとてつもなく難易度が上がるという事ですね...。例えば、「酔わないように」かつ「分かりやすいように」かつ「VRでの世界観に合うように」など色々考えないといけない事に。
 プレイヤーの体力表示に関しては、自機のガラスにひびが入るといった演出も考えたのですが、今回は画面端に数値とアイコンを常時表示しておきます。他に、敵UFOの位置表示は表示しておくべきかとは思ったのですが、どうしたらいいのか考えものですね...。といっても、実装はしませんでしたが、実装するとなるとどうするべきでしょうか...。UIデザイナーに構想を放り投げたい気分です。

UIの作成

 VRのUIはブループリントウィジェットを一つのアクターとして独立させます。つまり、UIを板ポリとして表示する「3Dウィジェット」として扱います。その為、ブループリントウィジェットは通常通りに作成します。といっても、ウィジェットの中身をどうするのか問題はありますが...。

  1. ブループリントウィジェットとBPアクター(3Dウィジェット)の両方を作成
  2. 作成したアクターに対してWidget Componentを追加
  3. Widget Component > 詳細 > ユーザーインターフェース > Widget Class」に作成したブループリントウィジェットを設定
  4. 「詳細 > ユーザーインターフェース > Draw Size」のサイズをビューポートを見ながら調整(デフォルトでは一部分しか表示されないからです)
    UI ユーザーインターフェース.png

 作成したアクターをスポーン・配置するだけでとりあえず表示されるようになります。勿論、値の変更などは通常通り可能です。

UIの操作

 UIの「ボタン・スライダー」などはどうやって判定をするのかというと、プレイヤー側に設定する事で判定が可能になります。それが、前述したWidgetInteractionL/Rになります。

  1. プレイヤー側でWidget Interaction Componentを追加
  2. 上記で左右用に追加した場合(複数個)は「Widget Interaction Component > 詳細 > インタラクション > Pointer Index」を変更(値が同じだと判定が同じになってしまいます)
  3. 同じく「詳細 > インタラクション > Interaction Distance」の値を大きくしておく(割と距離が短いので数値を大きめに調整しておいた方がいいです)
    UI インタラクション.png
  4. Widget Interaction Componentの変数を取得
  5. インプットアクションとPress Pointer Key / Release Pointer Key関数を召喚
  6. 上記関数の引数に設定
    1. ターゲット:コンポーネントの変数
    2. Key:「マウスの左ボタン」
      自機 UI インプット.png

 後は、通常通りに「ボタン > 詳細 > イベント > On Clicked」でクリックイベントを追加して処理を記入します。スライダーなども同じ感じで、値の変更なら変数のSet Value関数になります。
 といった感じで、凄く簡単に判定が可能になりますね。そして、前述したLaserL/Rに関してはUIへの指し示す先を表すための表示です。実は「デバッグ > Show Debug」をONにする事で、とりあえずライン表示が可能です。

UIを微調整&結果

 Widget側で更に調整するならば、「ボタン > 詳細 > アピアランス > StyleHovered / PressedImage Size」で指している / 押された時にボタンの大きさが変わります。更に、「詳細 > アピアランス > StyleHovered / PressedTint」を変更すれば色を変更可能です。VRになるとUIを指せているのか分かりにくいので、少しでも変化を加えます。
UI アピアランス.png
 これで簡易的な操作付きのUIは完了で、実装した結果が下図になります。
UI.gif
 ですが、単純なUIですし、ゲーム中に使用できるかというと微妙ですね...。どうなんでしょう。タイトル画面やポーズ画面ならまだありですね。
 確か、ビートセイバーの曲セレクト画面は下図のUIだったはずです2。結局は使い方しだいですね3
UI 例.png
 詳しい使い方は下記サイトを覗いてみて下さい。

作成したゲーム

 素早く見渡したりするので、画面酔い注意です。

 こんな感じで極々シンプルなゲームのようなものです。ですが、初めてのVRゲーム制作なので手探り状態で始めていましたが、ある程度のクオリティはあるのかな?と思います。こんなゲームですが、VRになると「わぁ、ゲームだぁ~」に思えてしまうのは、目が肥えていないからでしょうか?
 UI(体力表示)の位置がかなり真ん中よりに表示されていますが、VR上では画面端に見えています。ここもVRじゃないと理解できない点なのかもしれません。

最適化

 完成したぞーと思い「実行」を押してみると、結構重い事が判明したりするかもしれません。やはり、PCと比べるとどうしても性能は落ちてしまうので仕方ないです。
 その為、色々OculusQuest2用に調整しないといけません。例えば、全体の描画解像度を落としたり、テクスチャ解像度を落としたり、レンダリング設定をいじったりするなど、色々と調整可能です。詳細は下記サイトを覗いて見て下さい。

最後に

 計3回に渡ってOculusQuest2を使った簡易VRゲームを作成しました。こんなに書くことになるとは思ってもいなかったのですが、色々と良い経験にはなったと思います。今度作るならガチガチのゲームを作ってみたいですね4
 全ての記事を見れば、UE4でVRゲームを作れる基礎知識を手に入れられるはずです。といっても、この記事だけではなく他の記事も参考にしながら、楽しいVRゲーム制作をしていきましょー。


 次回は学校での卒業制作にあたって、入手・使用した知識・技術をまとめた記事を上げる予定です。その後、待望?のユウナマ制作の続きに取り掛かります。長い間、記事を全く上げられずホントに申し訳ないです。
 卒業制作や引っ越しなどリアルイベントも色々ありましたし、モチベーションを保つのがホント難しいですね。つまり、今までは色々忙しくてなかなか記事を上げられませんでした。ですが、2・3月中は特に何もないので、1~2週間に1回のペースで上げるようにします。4月以降は分かりませんが...。

参考サイト

  1. 引数のRollは「ロール・ピッチ・ヨー」の内、ロールを有効にする設定みたいです。What does ‘roll’ mean in the Random Rotator?より。

  2. Windows10のロゴに見えてきたのは私だけでしょうか?

  3. それを言ってしまったら終わり

  4. ※ 作るとは言っていない

5
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?