本リポジトリはオライリー・ジャパン発行書籍『UnityによるVRアプリケーション開発』(原書名『Unity Virtual Reality Projects』)のサポートサイトです。
VRやARについて日本語で質問できるフォーラムがあります。 お気軽にご参加ください。本書の翻訳者も参加していますので、本書に関することも質問して頂けます。
- 付録A Gear VR 用のビルドとタッチパッドからの入力
- 付録B Daydreamコントローラーを使ってみる
- Unity 5.6での対応方法など、本書発売当時から更新のあった情報も追記してあります
Unityの5.6より前のバージョンはサポート対象外となりました。(CardboardおよびDaydreamにネイティブ対応しているUnityのみが対象です。)
GvrViewerMain
が無くなり、その代わりにGvrEditorEmulator
が追加されました。このGvrEditorEmulator
はUnityのエディターでプレビューする際にのみ必要なものです。
これらの変更に伴い、第1刷、第2刷ともに本文に下記の訂正があります。
- P.51 「3.4.4 プレハブの追加」において必要な手順は以下の一つのみとなります。プレハブの変更の適用も不要です。
- Project パネルの Assets/GoogleVR/Prefabs フォルダーの中から
GvrEditorEmulator
を見つけて、[Hierarchy]パネルにドラッグします。
- Project パネルの Assets/GoogleVR/Prefabs フォルダーの中から
- P. 135 「Google CardboardもHMDの向きをリセットする同様の機能を持っています。もちろん位置のトラッキング機能はありません。GvrViewer.Recenter() を呼ぶことで向きとモーションセンサーだけがリセットされます。」という記述を削除
- CardboardでもOculusと同様に
InputTracking.Recenter()
で再センタリング可能です。
- CardboardでもOculusと同様に
- P.239 「10.4.2 Google Cardboard での利用」
- 「FPSControllerに加えてGoogle VR SDKのプレハブ、GvrViewerMainを使用する必要があります。」を削除。
- P.240
- 「2. ProjectパネルのAssets/GoogleVR/PrefabsからGvrViewerMainを見つけて、現在のシーンにドラッグします。」を削除。
- NetworkStart.csスクリプトの修正内容はこちらを参照ください。
- 「このスクリプトでは、gvrMain の値を public な GameObject として定義します。Unity エ ディターにて、HierarchyパネルのNetworkControllerを選択した状態で、Inspectorの NetworkStart (Script) コンポーネントに Gvr Main の枠があるのを確認して、GvrViewerMain を Gvr Main にドラッグします。」を削除。
- P.241 「*1 訳注」の内容は下記の「ビルド設定の修正」と同様になります。
- P.253 「A.2.3 メインカメラの設定」の内容は不要となります。
このリポジトリにある各章のプロジェクトで使用していたGvrViewerMain
は削除してあります。
Unityのエディターでプレビューをする際はGoogle VR SDK for Unityをダウンロード、インポートしてGvrEditorEmulator
を[Hierarchy]パネルに追加してください。
(もしGoogle VR SDK for Unity v1.40以前を使用する必要がある場合はbefore_GVR1.50タグを参照してください)
2017年3月31日にCardboardとDaydreamにネイティブ対応したUnity 5.6の正式版がリリースされました。それに伴い、本書で扱うプロジェクトのビルド設定とスクリプトに修正が必要な箇所があります。
P.52の訳注にて「UnityもCardboardやDaydreamにネイティブ対応することを表明しているため、将来のバージョンではこのチェックを入れて、さらに[+]ボタンを押して選択肢の中からGoogle VR、Cardboard、Daydream等の要素を選択して追加するという操作になることが想定されます。」と追記しておりましたが、その時が来たということになります。
以下はP.51の「3.4.5 ビルドの設定」をUnity 5.6以降用に修正したものです。変更点は[Virtual Reality Supported]のチェックボックスをONにすることです。(以前のバージョンではこのチェックボックスはOFFにしていましたが、UnityがCardboardとDaydreamにネイティブ対応したことにより、今後はこの設定が必要になります)
-
メインメニューの[File]→[Build Settings...]を選択します。
-
[Scenes In Build]に現在のシーンがない場合は、[Add Open Scenes]をクリックします。
-
左側のPlatformの一覧から[Android]または[iOS]を選択して、[Switch Platform]をクリックします。
-
それから、[Player Settings...]をクリックします。InspectorパネルにPlayer Settingsが表示されます。
-
[Other Settings]の中にある[Virtual Reality Supported]のチェックをONにします 。
-
図1のように[Virtual Reality Supported]チェックボックスの下に[Cardboard]もしくは[Daydream]の文字が表示されていることも確認します。もし表示されていなければ[+]ボタンを押して選択肢の中から追加します。(iOSの場合は[Cardboard]のみが表示されます。)
-
[Other Settings]→[Identification]→[Bundle Identifier]にcom.YourName.VRisAwesomeなどのように有効な文字列を入力します。
※ [Resolution and Presentation]の中にある[Default Orientation]は、[Virtual Reality Supported]のチェックをONにすると自動設定されます。
図1 Virtual Reality Supportedのチェックボックス
本書の複数箇所で使用しているClicker.cs
というスクリプトをClicker.cs修正版のように修正する必要があります。(このリポジトリにあるものは修正済みです)
これは、現状のUnity 5.6 (5.6.0f3) とGoogle VR SDK for Unity 1.40の組合せでは、これまで使用していたGvrViewer.Instance.Triggered
ではCardboardのトリガー操作を検知できず、GoogleのサンプルでもGvrViewer.Instance.Triggered
は使われていない様子のため、GvrPointerInputModule.cs を参考に、Cardboardの場合にGvrViewer.Instance.Triggered
を使わないよう、且つDaydreamでもOculus系(Rift, Gear VR)でも大丈夫なように修正したものです。
サンプルコードの解説は本書籍をご覧ください。
Unity 5.4.x 系以降のバージョンをお使いの場合は https://github.com/oreilly-japan/unity-virtual-reality-projects-ja/archive/master.zip から、
Unity 5.3.x 系をお使いの場合は https://github.com/oreilly-japan/unity-virtual-reality-projects-ja/archive/unity53x.zip から、それぞれダウンロードしてください。
code フォルダーの下に本書のUnityプロジェクトを章ごとに完成した状態で用意してあります。ただし、Unity標準アセットやGoogle VR SDK等は含まれていないので、プロジェクトをUnityで開いたら次の手順で必要なものをインポートしてください。
(本書の手順に従って新規にプロジェクトを作成したい方は、resources
フォルダーの下に各章ごとに必要なリソースファイルを置いてありますので、必要に応じてお使いください。)
- メインメニューの[Assets]を選択します。それから[Import Package]→[Characters]の順に操作します。
- インポート可能なすべてのものをリスト表示したインポートダイアログがポップアップするので[Import]をクリックします。
- 同様にして[Assets]→[Import Package]→[Effects]の順に操作し、ポップアップしたインポートダイアログで[Import]をクリックします。
- 同様にして[Assets]→[Import Package]→[ParticleSystems]の順に操作し、ポップアップしたインポートダイアログで[Import]をクリックします。
- ウェブブラウザでhttps://developers.google.com/vr/unity/downloadを開いて、Google VR SDK for Unityをダウンロードします。
- Unityのメインメニューの[Assets]から[Import Package]→[Custom Package...]を選択します。
- ダウンロードした
GoogleVRForUnity.unitypackage
というファイルを見つけて選択します。 - すべてのアセットにチェックが付いていることを確認して、[Import]をクリックします。
- Projectパネルの
Assets
を選択し、シーン(Unityのロゴがアイコンになっているもの)をダブルクリックして開くとSceneビューにオブジェクトが表示されます。
付録 B の Daydream用アプリケーション開発環境の設定はこちら
日本語版で検証に使用した各ソフトウェアのバージョン、およびハードウェアは次のとおりです。
- Unity 5.6.0f3, 5.5.0f3, 5.4.2f2-GVR12, 5.4.2f1, 5.3.6f1
- Blender 2.77
- Android SDK API level 23
- Xcode 8.3, 7.3.1
- Google VR SDK for Unity v1.40
- Samsung Galaxy S6 edge(Android 6.0.1)
- Nexus 5X(Android 7.0)
- Moto Z (Android 7.0)
- iPhone 6 Plus(iOS 9.3.2)
- iPhone SE (iOS 10.3.1)
- MacBook Pro Retina, 13-inch, Mid 2014(Mac OS X 10.12.4)
- Windows PC, GPU: NVIDIA GeForce GTX980Ti(Windows 8)
- Oculus Rift製品版、およびDK2
- Google Cardboard
- Sumsung Gear VR
- Daydream View
下記の誤りがありました。お詫びして訂正いたします。
本ページに掲載されていない誤植・間違いを見つけた方は、japan@oreilly.co.jpまでお知らせください。
誤
車アイコンを押して[Rest]を選択します。
正
車アイコンを押して[Reset]を選択します。
誤
DetectMoveDown()関数はUpdaet()が呼ばれるたびにカメラのX回転(角)を取得して
正
DetectMoveDown()関数はUpdate()が呼ばれるたびにカメラのX回転(角)を取得して
誤
_機能:_ レンガが空中からトランポリンに落ちてきて、上に跳ね返り、重力の影響により減衰する。
正
_機能:_ レンガが空中からトランポリンに落ちると上に跳ね返り、やがて重力の影響により落ちてくる。
誤
_機能:_ 一人称キャラクターがトランポリンに落ちてきて、上に跳ね返り、重力の影響により減衰する。
正
_機能:_ 一人称キャラクターがトランポリンに乗ると上に跳ね返り、やがて重力の影響により落ちてくる。