どうも、Reveです。
前回のQuest2記事から早3か月、時が過ぎるのは早いものです。
今回は、UnityでQuest2用アプリの開発環境構築について書いていこうと思います。
Quest2の設定
Oculusアプリのインストール
Quest2用アプリを実機でテストするには「開発者モード」を有効にしなくてはいけませんが、これにはスマホ用アプリが必要です(Quest2本体のみでは不可)。
つまり、Quest2とペアリングしたスマホでないと開発者モードを有効にできません。
Quest2用アプリは公式サイト、またはストア(Google Play or AppStore)からインストールできます。
ペアリング
アプリのインストールが完了したら、スマホとQuest2の紐づけを行います。
インストール、およびペアリングの詳しい手順はこちらをご参照ください(画面キャプチャもあります)。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/03eb5049643e7814c27bf19750b0d2b2.png)
なお、(2021年時点で)Oculus2のセットアップには実質facebookアカウントが必須です。また、Oculusアカウントを持っていた場合、統合も求められるようです(が、トラブルも少なからず報告されているようです)。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/1c608d1107d0e2fc26fa81f793e68223.jpg)
ちなみに、2022年内にfacebookアカウントログインが不要になるとの話もありますが、正式な時期は未定のようです。
開発者モードの有効化
ペアリングが済んだら、以下の通りアプリでQuest2の開発者モードを有効にします。
- 左上のデバイス一覧から「Quest/Quest 2」を選択
- ヘッドセットの設定から「開発者モード」を選択
- 開発者モードを有効化
![](https://blog.revetronique.com/wp-content/uploads/2022/03/Screenshot_2022-03-30-23-29-13-871_com.oculus.twilight-576x1024.jpg)
![](https://blog.revetronique.com/wp-content/uploads/2022/03/Screenshot_2022-03-30-23-28-56-452_com.oculus.twilight-576x1024.jpg)
![](https://blog.revetronique.com/wp-content/uploads/2022/03/Screenshot_2022-03-30-23-29-27-538_com.oculus.twilight-576x1024.jpg)
これでハードウェア(Quest2)の準備が整いました。
Unityでのアプリ作成
Unityのインストール
とにもかくにも、Unityをインストールしないと始まりません。
Unity HubからUnity本体、および各種パッケージ(Android SDKなど)のインストールするのがおすすめです。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/ef0e462c8dee61c915c05b52cc13be41.jpg)
Unity Hubのインストールが完了したら、実行してUnity本体のインストールを進めてください。
画面が出たら、左のメニューから「インストール」を選んで、右の青いインストールボタンを押しましょう。あとは、画面の指示に従って必要なものを選びます。
(Unityインストールの記事URL?)
Androidビルド用モジュールの追加
Quest2はいわゆるAndroidスマホの様なものなので、アプリ開発にはAndroid SDKが必須です。
Unity本体のインストールでバージョンを選んだあと、追加のモジュールを選択する画面が出てきます。そこで、「Android Build Support」にチェックを入れてから実行ボタンを押してインストールしましょう。
![](https://blog.revetronique.com/wp-content/uploads/2022/03/Unity_install-Android-1024x706.png)
なお、インストールしたUnityがAndroid SDKの最新版に対応していないと注意される事もありますが、その場合はUnity Hub経由でインストールできるSDKを使えばOKです。
プロジェクト作成
Unity本体をインストールしたら、さっそく起動しましょう。
そこで、新規プロジェクトを「3D」か「Universal Render Pipeline(URP)」テンプレートで作成します。
![](https://blog.revetronique.com/wp-content/uploads/2022/04/Unity_newproject1-1024x710.png)
![](https://blog.revetronique.com/wp-content/uploads/2022/04/Unity_newproject2.png)
なお、3D(デフォルト)とURPの大まかな違いはこちらにまとめられています。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/1b6e00edfe9eb3ab951211b3e27da1d7.jpg)
結論としては、URPの方が上位互換なのでURPを選んでおけばOKです(Quest2にも対応してます)が、以下の様に時間や手間が惜しい方は3Dの方が適しているかと思います。
- セットアップの手間も惜しい時
- 古いアセットを利用したい場合
- Unityに初めて触れる初心者
Oculus Integrationのインポート
続いて、Quest2アプリ開発用SDK(Oculus Integration)をUnityにインポートします。URLにアクセスして、以下の手順で進めていきます。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/a2bfe614dafc4a06b2e9dab9305415ea.jpg)
- 「Add to My Asset」ボタンを押してアセットをダウンロード
- ブラウザからの通知、または1.と同じボタンを押してUnityに移動
- 自動的に開くPackage Managerで、「Download」ボタンを押してプロジェクトに追加
- もう一度ボタン(表示は「Import」)を押して、開いたポップアップからアセットをインポート
![](https://blog.revetronique.com/wp-content/uploads/2022/04/Unity-AssetStoreOculus-1024x576.png)
![](https://blog.revetronique.com/wp-content/uploads/2022/04/Unity-OculusIntegration-1024x576.png)
このインポートですが、本当に長い時間がかかります。あまり使わないと思われるファイル(Oculus/Avatarなど)を外しておくと多少短くなります。
また、以下のようにプロジェクトを設定しておくと、プロジェクト全体の再インポートが走らず効率が良くなるようです。
- (Build Settings) プラットフォーム:Android、Texture Compression:ASTC
- (Project Settings) Color Space:Linear、Auto Graphics APIを無効化、Graphics APIsのVulkanまたはOpenGLES3を削除、Script Backend:IL2CPP、Target Architecture:ARM64にチェック
アプリのビルド
ビルド設定
インポートお疲れさまでした。ここからはビルドの準備に入ります。
- File > Build Settings を開いてPlatformにAndroidを選択し、Switch Platformをクリック
- Build Settingsの左下にあるPlayer Settingsをクリック
- InspectorウィンドウのOther Settingsを選択して,Minimum API Levelを19以上に変更します(デフォルトでは16)
![](https://blog.revetronique.com/wp-content/uploads/2022/04/Unity-Oculus-BuildSetting.png)
![](https://blog.revetronique.com/wp-content/uploads/2022/04/Unity-ProjectSetting-APILevel.png)
なお、ターゲットレベルが「Automatic (highest installed)」で、APIレベル26のSDKをインストールしておけば、最小レベルは気にしなくてもほぼ問題ありません。
今のQuest2のAPIレベルなどはここから確認できます。
デバイスへの書き込み (Build and Run)
設定が完了したら、実機への書き込み準備に移ります。
まずはPCとOculus Quest2をUSB Type-Cケーブルで接続します.PCとQuest2をつないだら、Quest2側で接続の確認を求められるので許可してください。
USB-Cコネクタを有するPCならOculus Quest付属のケーブルが使えますが、違う場合は別途ケーブルや変換アダプタを用意する必要があります.
試しに現在のSceneに適当にキューブを配置してみて File → Build And Run をクリックします.
UnityエディタのPlayモードで実行 (要Oculus Link)
Oculus Linkを設定していれば、Playモードでエディタから実行可能です。いちいちビルドする必要がないため、すぐに実行できてデバッグ作業もはかどります。ただし、時々フリーズすることがある点はご注意ください(詳細は前回の記事で)。
余談
ちなみに、最近はOculus Integrationをインストールせず、既存のOpen XRからでもアプリ開発ができるみたいです。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/77d5242cde7404bcbfcd6b99ee14a336.jpg)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Fadvent-calendar-ogp-background-f625e957b80c4bd8dd47b724be996090.jpg?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9VW5pdHkyMDIxLjIuNGYxJUUzJTgxJUFFVVJQJUUzJTgxJUE3JUUzJTgwJTgxT3BlblhSJUUzJTgxJUFFJUUzJTgxJUJGJUUzJTgxJUE3VlIlRTMlODIlQTIlRTMlODMlOTclRTMlODMlQUElRTklOTYlOEIlRTclOTklQkElRTMlODIlOTIlRTMlODElOTklRTMlODIlOEImdHh0LWNvbG9yPSUyMzNBM0MzQyZ0eHQtZm9udD1IaXJhZ2lubyUyMFNhbnMlMjBXNiZ0eHQtc2l6ZT01NiZ0eHQtY2xpcD1lbGxpcHNpcyZ0eHQtYWxpZ249bGVmdCUyQ21pZGRsZSZzPTJiNjZmODA1ZDJhMmE5NzE0ZWMzMDQ0YmRmNThlMTU5&mark-x=142&mark-y=151&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTcxNiZ0eHQ9JTQwS2F6dV9TYWNrJnR4dC1jb2xvcj0lMjMzQTNDM0MmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzImdHh0LWFsaWduPWxlZnQlMkN0b3Amcz00YjBkZDk4YjIyN2Y4NDBkMDZmOWRhNzEyNWI4YWRjYQ&blend-x=142&blend-y=491&blend-mode=normal&s=5bcf64bb76e3cdb6af92395d9f4066a3)
少し前まではハンドトラッキングなどの一部機能に制限がありましたが、最近は使えるようです。
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/b857920f90bcd3c70212a9f1a29c2487.jpg)
参考
Unityで作ったアプリをOculus Questで動かす
細かい点も含めて一通りの情報が網羅されています
![](https://blog.revetronique.com/wp-content/uploads/cocoon-resources/blog-card-cache/fabbffec1dbc51a19c3ccc67112b7948.jpg)
Unity + Oculus Quest(Meta Quest)開発メモ
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fcdn.qiita.com%2Fassets%2Fpublic%2Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png?ixlib=rb-4.0.0&w=1200&mark64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9VW5pdHklRTMlODElQTclRTQlQkQlOUMlRTMlODElQTMlRTMlODElOUYlRTMlODIlQTIlRTMlODMlOTclRTMlODMlQUElRTMlODIlOTJPY3VsdXMlMjBRdWVzdCVFMyU4MSVBNyVFNSU4QiU5NSVFMyU4MSU4QiVFMyU4MSU5OSZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTU2JnR4dC1jbGlwPWVsbGlwc2lzJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9OGFhYmZlNWFhMzIyNjIxYzc1MGNjMDA2ZTU5ZmM3NTA&mark-x=142&mark-y=112&blend64=aHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTcxNiZ0eHQ9JTQwcGlyYSZ0eHQtY29sb3I9JTIzMjEyMTIxJnR4dC1mb250PUhpcmFnaW5vJTIwU2FucyUyMFc2JnR4dC1zaXplPTMyJnR4dC1hbGlnbj1sZWZ0JTJDdG9wJnM9ZDE5OWM1ZDA1MzhmMTM1YTBkMWJmYzFiMTY3NTdmNDk&blend-x=142&blend-y=491&blend-mode=normal&s=f8783fe33d2b20fe071bde9ca44e6c1e)
【Oculus Quest開発メモ】開発初期設定まとめ Oculus Integration【Unity】