XR
XR SDKs

VR 概要

Unity VR lets you target virtual reality devices directly from Unity, without any external plug-ins in projects. It provides a base API and feature set with compatibility for multiple devices. It has been designed to provide forward compatibility for future devices and software.

Note: XR is an umbrella term which encompassess virtual reality (VR), augmented reality (AR), and other similar technologies. We are in the process of updating our XR documentation, but for now this documentation refers mainly to just VR.

Unity’s XR API has been updated to reflect the broader umbrella term “XR” but much of the documentation currently still uses the term “VR”. The XR API surface is minimal by design, but will expand as XR continues to grow.

ネイティブの VR サポートを使用することにより、以下が可能になります。

  • 各 VR デバイスの安定バージョン
  • さまざまな VR デバイスと通信するための 1つの API インターフェース
  • 各デバイスごとの、外部プラグイン無しのクリーンなプロジェクトフォルダー
  • アプリケーション内で複数デバイスを扱い、その間を切り替えることが可能な性能
  • パフォーマンスの向上 (低水準の Unity エンジン最適化がネイティブデバイスに対し可能になりました)

Unity の VR サポートを有効にする

ゲームのビルドとエディターの VR を使用可能にするには、Player Settings を開き(menu: Edit > Project Settings > Player)、 Other Settings を選択し Virtual Reality Supported のボックスをチェックします。各ビルドターゲットごとにこの設定を行います。スタンドアローンビルドの VR を有効にしても、Android のサポートを有効にしたことにはなりません (逆の場合も同様)。

その下に表示された Virtual Reality SDKs のリストに、それぞれのビルドターゲットの VR デバイスを追加、または、削除します。リストの順番は、ランタイムに Unity が VR デバイスを有効にする順番です。最初に適切に初期化されたデバイスが有効にされます。このリストの順番はビルドされたプレイヤー内でも同じです。

アプリのビルド: 起動するデバイスを選ぶ

ビルドされたアプリケーションは Player Settings リスト (前出の Unity の VR サポートを有効にする 参照) と同じ順番で、デバイスを初期化し有効にします。ビルド時にリストにないデバイスは、最終的なビルドで使用できません。

Including None as a device in the list allows you to default to a non-VR application before attempting a VR device’s initialization. If you place None at the top of the list, the application starts with VR disabled. Then, you can then enable and disable VR devices that are present in your list through script using XR.XRSettings.LoadDeviceByName.

If initialization of the device you attempt to switch to fails, Unity disables VR with that device still set as the active VR device. When you switch devices (XRSettings.LoadDeviceByName) or enable XR (XR.XRSettings-enabled), the built application attempts to initialize again.

特定のデバイスで開始するためのコマンドライン引数は以下のとおりです。

-vrmode DEVICETYPE

where DEVICETYPE is one of the names from the supported XR supported devices list.

MyGame.exe -vrmode oculus

VR を有効にすると、何が起きるか

Unity で VR を有効にすると、自動的にいくらか変化が起こります。

自動的にヘッドマウントディスプレイにレンダリング

シーンのすべてのカメラは、直接ヘッドマウントディスプレイ (HMD) にレンダリングできます。ビューとプロジェクション行列が自動的に調整され、ヘッドトラッキング、位置トラッキング、field of view を処理します。

Camera コンポーネントの stereoTargetEye プロパティーを使用して HMD へのレンダリングを無効にすることが可能です。その他に、 Target Texture プロパティーを使って、カメラがレンダーテクスチャにレンダリングするように設定できます。

  • stereoTargetEye プロパティーを使用して、特定の目だけを HMD にレンダリングするようカメラを設定することもできます。これは、スナイパースコープや、立体映像のビデオなどの特殊なエフェクトに役立ちます。これを行うには、シーンにカメラを 2つ加え、1つのターゲットを左目、もう 1つを右目に合わせます。それぞれの目に送るものを微調整するために、レイヤーマスクを設定します。

ヘッドトラッキングされた自動入力

使用するデバイスがヘッドマウントの場合、ヘッドトラッキングと適切な Field of View (FOV) は自動的にカメラに適用されます。手動で FOV を特定の値に設定することもできますが、Camera の Transform の値は直接設定することはできません。詳しくは、後出の カメラを理解する のセクションを参照してください。

ヘッドトラッキングと位置トラッキングが自動的に適用され、フレームをレンダリングする前に、位置と向きをできるだけ正確にユーザーのものと一致させます。こうすることにより、快適な VR 体験が実現し、ユーザーが吐き気をもよおすことを防ぎます。

カメラを理解する

カメラを動かしたり回転させたりするには、他のゲームオブジェクトの子としてアタッチします。そのため、カメラがアタッチした親の Transform が変化すると、カメラにも影響します。このことは、スクリプトを使ってカメラを動かしたり回転させる場合でも同じです。

カメラの位置と向きを、ユーザーがニュートラルな姿勢で見ている状態と考えます。

座ったまま (seated) とルームスケール (room-scale) の VR 体験には相違点があります。

  • デバイスがルームスケールの体験をサポートする場合は、ユーザーのプレイスペースの中央がカメラの開始位置になります。
  • Using the seated experience, you can reset Cameras to the neutral position using XR.InputTracking.Recenter().

Each Camera that is rendering to the device automatically replaces the FOV of the Camera with the FOV that the user input in the software settings for each VR SDK. The user cannot change the field of view during runtime, because this behaviour is known to induce motion sickness.

エディター モード

  • VR デバイスが Unity エディターモード をサポートしている場合、エディターで再生ボタンを押すとデバイス上で直接テストすることができます。

stereoTargetEye を左目、または両目に設定すると、左目がゲームビューウィンドウにレンダリングされます。stereoTargetEye を右目に設定すると、右目がゲームビューウィンドウにレンダリングされます。

  • ゲームビューで左右の目のビューを横並びにするには、2つのカメラを作成します。片方を左目、もう片方を右目に設定し、それらを表示するビューポートを横並びにします。

エディターでの実行にはオーバーヘッドがあり、遅延やブレが発生することがあります。Unity IDE は各ウィンドウをレンダリングする必要があるため、ゲームビューの “Maximize on Play” を使ってエディターのレンダリングオーバーヘッドを削減してください。

パフォーマンスを検証する最良の方法は、ターゲットプラットフォームのビルドを作成して直接実行することです。開発ビルド以外で実行するほうが良いパフォーマンスを得られますが、開発ビルドを使うと、より詳しいパフォーマンスプロファイリングを得るために Unity プロファイラーに接続することができます。

Unity を使った VR 開発で推奨のハードウェアとソフトウェア

ハードウェア

ターゲット HMD に近いフレームレートを達成することは、よい VR 体験のためには不可欠です。これは、HMD で使われる画面のリフレッシュレートと一致しなければなりません。フレームレートが HMD のリフレッシュレートを下回ると、とても目立ち、しばしばプレイヤーが吐き気を感じる原因になります。

VR デバイスのリフレッシュレート

VR デバイス リフレッシュレート
Gear VR 60hz
Oculus CV1 90hz
Vive 90hz

ソフトウェア

  • Windows: Windows 7、8、8.1、10 はすべて互換性あり。

  • Android: Android OS Lollipop 5.1 以降。

  • OS X: OSX 10.9 以降とランタイムに Oculus 0.5.0.1。ただし、Oculus は OS X 対し開発停止 しているため、Unity でネイティブの VR 機能を使うには Windows を使用してください。

  • グラフィックスカードドライバ: ドライバを更新するよう注意してください。すべてのデバイスは最新のドライバに対応しています。そのため、古いドライバはサポートされていない場合があります。

IOSデバイスの要件 Each VR device requires that you have appropriate runtime installed on your machine. For example, to develop and run Oculus within Unity, you need to have the Oculus runtime (also known as Oculus Home) installed on your machine. For Vive, you need to have Steam and SteamVR installed.

Depending on what version of Unity you are using, the runtime versions for each specific device that is supported by Unity may differ. You can find runtime versions in the release notes of each major and minor Unity release.

With some version updates, previous runtime versions are no longer supported. This means that native Unity VR support does not work with earlier runtime versions, but continues to work with new runtime versions.

Unity native VR support does not read plug-ins from within your project’s folder, so including earlier versions of the plug-in with native support will fail if you have VR support enabled. If you wish to use an earlier version with a release of Unity that no longer supports that version, disable Native VR Support (go to Other Settings and uncheck Virtual Reality Supported). You can then access the plug-in like any other 3rd party plugin. See the section above on Enabling Unity VR Support for more details.

XR
XR SDKs