OculusGoを買いました。
気分が上がってきたのでUnityで遊びたくなりましたがコントローラー周りで詰まり解決方法を探ったまとめです。
なお、昨日からUnityに入門するため間違い等ありましたらご指摘&修正リクをお願い致します。m(_ _)m
Unity入門を遊んだ後に
https://unity3d.com/jp/learn/tutorials/projects/hajiuni-jp
この玉転がしのチュートリアルの後にこのゲームをOculusGoに対応させます。
上記チュートリアルを終わった後に追加作業でOculusGoに対応します。
OculusGoを開発者モードにしてAndroid開発環境を入れる
これは以下に情報があります。
https://qiita.com/Hirai0827/items/f62588cc7d5c6c17e364
アプリのVR対応
まずメニューからFile->BuildSettingに行きます
data:image/s3,"s3://crabby-images/2dc9c/2dc9c2c115cddf6c8e40734988746e99c6ed179e" alt="Build_Settings_と_Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_PC__Mac___Linux_Standalone__Personal___Metal_.png"
data:image/s3,"s3://crabby-images/42f0e/42f0e63d5f56ef8f3a9e352c1293e670dafff1a3" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_PC__Mac___Linux_Standalone__Personal___Metal_.png"
data:image/s3,"s3://crabby-images/0dd9b/0dd9b5e54729b1bbbd2dded0c22f1f269af77fd2" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_PC__Mac___Linux_Standalone__Personal___Metal_.png"
次はXR Settingsの項目です。
Virtual Rearity Suppoerted
を有効化し
Vertula Rearity SDKs
にOculus
を追加します
Stereo Rendering Methods
をSingleに設定します。
この状態でFile
-> Build & Run
を実行すると見た目だけVRに対応します。
コントローラー側の対応
でも肝心の操作が効きません。
data:image/s3,"s3://crabby-images/575e5/575e5719bdd36ea0de34b2724d198bf077441646" alt="https://qiita-image-store.s3.amazonaws.com/0/3844/a22b6ef7-80ea-f443-b7da-ba2a5b141d22.jpeg"
ピクリとも動かない。
Oculus Integration
を導入します。
メニューのwindow
-> Asset Store
を選びOculus Integration
で検索します
data:image/s3,"s3://crabby-images/b2aa8/b2aa83e72e95e13579b997e651dfbce461605f2a" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_.png"
importします。
Oculus Integration
内にて提供されるOVRInput
を用いて入力の取得をおこないます。
PlayerControllerのコード修正
PlayerController.cs
を修正します。
現状は以下のようになっています。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class PlayerController : MonoBehaviour {
public float speed = 10;
void FixedUpdate(){
float x = Input.GetAxis("Horizontal");
float z = Input.GetAxis("Vertical");
Rigidbody rigidbody = GetComponent<Rigidbody>();
rigidbody.AddForce(x * speed, 0, z * speed);
}
}
先ず上記クラス名とファイル名を修正します。なんでかというとOculus Integration
内のクラスと名前衝突しているからです。
PlayerBallControllerとかにしておきます。
ここにOVRInputを利用するコードを追加します
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class PlayerBallController : MonoBehaviour {
public float speed = 10;
private void Start()
{
}
void Update() {
OVRInput.Update();
}
void FixedUpdate(){
#if UNITY_ANDROID && !UNITY_EDITOR
OVRInput.FixedUpdate();
//右手持ち決め打ちで実装
Vector2 vector = OVRInput.Get(OVRInput.Axis2D.PrimaryTouchpad, OVRInput.Controller.RTrackedRemote);
float x = vector.x;
float z = vector.y;
#else
float x = Input.GetAxis("Horizontal");
float z = Input.GetAxis("Vertical");
#endif
Rigidbody rigidbody = GetComponent<Rigidbody>();
rigidbody.AddForce(x * speed, 0, z * speed);
}
}
今回は、OVRInputを使うために呪いとしてFixedUpdate内で OVRInput.FixedUpdate()、Update内でOVRInput.Update()を呼ぶ必要があります。
(OVRManager
がシーン内に一つだけ存在する場合はこの呪いは不要です。)
更に、右手持ち前提でタッチパッド操作情報を拾うようにしました。いろいろ手を抜いています。
参考情報:
https://taiyaq.com/contents/jJMNL163YkNy1HQ1eN0G7pG9v
Unityの玉転がしチュートリアルを#OculusGoに対応させる(途中) pic.twitter.com/R7syXriz6S
— m0a (@abe00makoto) 2018年5月15日
ですが得点表示とか全部のアイテムを取り終わったらYou Win
と出るはずですがでません。
ここを次に対応させます。
得点表示できるようにする
今あるカメラの代わりに、OVRCameraRig
を使います。
以下のようにOculus/VR/Prefabs
内にあるOVRCameraRig
をシーンにドラッグして新しいカメラを作ります。更に元々あったMain Cameraを削除します。
data:image/s3,"s3://crabby-images/5e90d/5e90deedc0c126744a20e2462f7831e21979d644" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal__と_Assembly-CSharp_–_Assets_Script_PlayerBallController_cs__–_Visual_Studio_Community_2017_for_Mac.png"
Main Camera
と同じ設定をOVRCameraRig
に対して行います。
data:image/s3,"s3://crabby-images/6f1db/6f1dba79a281e4afd996bbe9d7a88dc5469208fa" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_2.png"
Transformに同じようにPositionを(0,9,-5)
とRotationを(60,0,0)
に設定します。
更にAdd Componentでチュートリアルで作成したFollowPlayer
スクリプトを取り込みます。
忘れずにTargetにPlayerをドラックして設定します。
ここまで行うとボールの動きに従って視線も動くようになります。
OVRCameraRig
追加に伴うコードの変更
OVRCameraRig
内にはOVR Manager
が入っています。
data:image/s3,"s3://crabby-images/5a9f9/5a9f90c89bdfe075c7e861f2a7cd407adb9080d3" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_9.png"
これに伴いPlayerのコードを変更します
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class PlayerBallController : MonoBehaviour {
public float speed = 10;
void FixedUpdate(){
#if UNITY_ANDROID && !UNITY_EDITOR
Vector2 vector = OVRInput.Get(OVRInput.Axis2D.PrimaryTouchpad, OVRInput.Controller.RTrackedRemote);
float x = vector.x;
float z = vector.y;
#else
float x = Input.GetAxis("Horizontal");
float z = Input.GetAxis("Vertical");
#endif
Rigidbody rigidbody = GetComponent<Rigidbody>();
rigidbody.AddForce(x * speed, 0, z * speed);
}
}
OVRInputを使うために呪いとして追加していた、FixedUpdate内で OVRInput.FixedUpdate()、Update内でOVRInput.Update()の呼び出しを削除しました。
UIを表示できるように
data:image/s3,"s3://crabby-images/81530/815309592d58ce816dbf7feb2e119de997104b46" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_3.png"
元々あった得点表示とYou Win
と表示するCanvasをOVRCameraRig
内のCenterEyEAnchor
内へドラックして移動します。
CenterEyEAnchor
内にコンテンツを設定することで常に目の前に表示できるようになります。
data:image/s3,"s3://crabby-images/f72ee/f72ee789afe24b4da11bde116339938a2d5615ba" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_5.png"
以下実際の設定値です。色々試行錯誤した結果です。
data:image/s3,"s3://crabby-images/920c1/920c18f840c99420d22bcd4d1834f550b4fe3333" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_6.png"
Canvas
について、
Render Mode
をWorld Space
にします。
Rect Transform
についてそれぞれ
Postionは(0,0,5)
、Width,Heightは(300,300)
Scale
を(0.02,0.02,0.02)
に設定しました。
data:image/s3,"s3://crabby-images/6d28a/6d28ac77a1d5f86294495d2d18385b40582f6b2a" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_7.png"
ScoreLabel
について、
Rect Transform
についてそれぞれ
Postionは(-90,-90,0)
、Width,Heightは(50,50)
Font Size
を40
に設定しました。
data:image/s3,"s3://crabby-images/c974b/c974bdf0bf442424d04d77d51f6793dc87be85e8" alt="Unity_2018_1_0f2_Personal__64bit__-_stage01_unity_-_Roll-a-Ball_-_Android__Personal___Metal_8.png"
WinnerLabel
について、
Rect Transform
についてそれぞれ
Postionは(20,0,0)
、Width,Heightは(280,80)
Font Size
を60
に設定しました。
完成
Unityの玉転がしチュートリアルを#OculusGoに対応させる(完成) pic.twitter.com/QwZUAHBbx5
— m0a (@abe00makoto) 2018年5月16日
まとめ
結構簡単にできました。
参考情報
http://bibinbaleo.hatenablog.com/entry/2018/05/14/001544
https://framesynthesis.jp/tech/unity/touch/