▼完成イメージ▼
プロジェクトは前回の続きから始めていきますので、手順に不安のある方は以下の記事内容を実施してから、戻ってきてください。
ARオブジェクトに影を付けるには、現実世界と同様に光と地面が必要になります。その二つの設定の仕方について説明していきます。
影の設定
地面の追加
まず、ARオブジェクトをSceneビューに表示します。
[Project]ウインドウ内のPrefab化した[Cube]を[Hierarchy]ウインドウにドラッグ&ドロップします。
data:image/s3,"s3://crabby-images/364e8/364e8f94f060c5915f004b2c35b60c31aae36a67" alt="01_Cube_add"
地面を追加します。
[GameObject]>[3D Object]>[Plane]をクリックします。Sceneビューに白い地面が設定されます。
data:image/s3,"s3://crabby-images/b4c20/b4c20e8a9626be44987bebbe12fd42dcd43297c8" alt="02_Plane_add"
光の設定
[Hierarchy]ウインドウ内の[Directional Light]をクリックして、[Inspector]ウインドウ内の[Light]>[Shadow Type]から影の付け方を選択します。ここでは、[Soft Shadows]を選択します。
data:image/s3,"s3://crabby-images/43c69/43c69036663bc42fae056c3b615fc3dd31acf3ee" alt="03_Light_mode"
Sceneビューを確認すると、[Cube]の影が[Plane]に投影されていることが確認できます。ただ、このままでは、プレイ[▷]時に[Cube]と[Plane]がそのまま表示されてしまうので、透明化をしていきます。
地面の透明化
Sceneビューに追加した白い地面を透明にするために、透明色を追加して、それを地面と関連付ける作業をします。
まずは、透明色を追加するためのマテリアルを作成します。
[Assets]>[Create]>[Material]をクリックします。[Project]ウインドウ内に、Materialが追加されますので、任意の名前を設定します。ここでは[TransMat]に変更します。
data:image/s3,"s3://crabby-images/63da1/63da11df61dd089c9406da2b0f715d0447de37bb" alt="04_material_add"
マテリアルを透明化します。
[Project]ウインドウ内の[TransMat]を選択し、[Inspector]ウインドウ内の[Shader]のプリダウンメニューから、検索で、[Transparent Shadow Receiver]を探して、クリックします。
data:image/s3,"s3://crabby-images/50935/509351878f8f0b4fd90a56bd228cefc84dee4d49" alt="05_transmat_shadow_receiver"
[Project]ウインドウ内の[TransMat]を[Scene]ビュー内の[Plane]にドラッグ&ドロップします。>[Import New Asset…]をクリックして、フォルダから任意のアセットを選択します。
data:image/s3,"s3://crabby-images/99a9f/99a9f0d6d249166f3c0e69604f9f76d57ac0d129" alt="06_Transmat_plane_add"
[Plane]が透明化されて見えなくなります。
data:image/s3,"s3://crabby-images/e4ab6/e4ab62a1a7ffc005d4634a769cf52aa6338c2a6c" alt="09_Trans_OK"
Prefab化
最後に、[Hierarchy]ウインドウ内を整理します。
[Hierarchy]ウインドウ内の[ImageTracker]>[Trackable]を選択した状態で、[GameObject>[Create Empty Child]をクリックします。
data:image/s3,"s3://crabby-images/d2146/d2146b1b798c781f33b55f059d2b6e6a374ee19a" alt="10_CreateEmpty"
[Hierarchy]ウインドウ内の[ImageTracker]>[Trackable]の配下に空のオブジェクトが作成されますので、任意の名前に変更します。ここでは、[Object]とします。
data:image/s3,"s3://crabby-images/b1636/b16367a174d9930ce4e612627b783a7e5a9fa3d1" alt="11_CreateObject"
[Hierarchy]ウインドウ内の[Object]に[Cube]と[Plane]>おドラッグ&ドロップして親子関係を作ります。
data:image/s3,"s3://crabby-images/108c3/108c3530d4dbd8976251c94ec7123e2bdf8da407" alt="12_Parent_object"
[Hierarchy]ウインドウ内の[Object]を[Project]ウインドウ内にドラッグ&ドロップして、Prefab化します。Prefab化した後は、[Hierarchy]ウインドウ内の[Object]を削除します。
data:image/s3,"s3://crabby-images/0018c/0018c41601f0b0d75394835c8ce376960ee290df" alt="13_Parent_prefab"
[Hierarchy]ウインドウ内の[ImageTracker]>[Trackable]を選択した状態で、[Project]ウインドウ内の先ほどPrefab化した[Object]を[Inspector]ウインドウ内の[Image Trackable(Script)]>[Drawable]にドラッグ&ドロップします。
data:image/s3,"s3://crabby-images/3a973/3a97353a137f2e59cd8ae65eb220d104e4acb75d" alt="14_Drawable_add"
ここまでで作業は完了です。
プレイ[▷]をクリックして、影が付いていることを確認します。