今回は、AR Foundationの平面検出機能を使い、タップした平面に箱を配置するということをしていきたいと思います!
学習に使った本はこちら!
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
Amazon Kindle Unlimited でもUnityの本はいっぱいあるんじゃ!!
前回の「ARで箱を表示してみよう!」の続きになりますので、まだ見ていない方はぜひ見てください!!
平面を検出する
AR Plane Managerの配置
AR Plane Manegerが、今回の主役となる平面検出を担ってくれる機能です。
これをAR Session Originに追加することで、平面検出を可能にしてくれます。
まずは、前回の画面を表示してください!
前回作成した「AR Session Origin」を編集していきます!
data:image/s3,"s3://crabby-images/9abb4/9abb433f9ef1fa93cdbe3bbff5e242047c61562c" alt=""
data:image/s3,"s3://crabby-images/9abb4/9abb433f9ef1fa93cdbe3bbff5e242047c61562c" alt=""
「AR Session Origin」を選択し、Add Component>AR Plane Managerを追加します!
data:image/s3,"s3://crabby-images/2660c/2660c69e12c6feed56b2a1757436a8b64e703caa" alt=""
data:image/s3,"s3://crabby-images/2660c/2660c69e12c6feed56b2a1757436a8b64e703caa" alt=""
下の画像のようになっていれば、OKです!
data:image/s3,"s3://crabby-images/a37b1/a37b14165961cb04bf6ad499ad13c791081814c6" alt=""
data:image/s3,"s3://crabby-images/a37b1/a37b14165961cb04bf6ad499ad13c791081814c6" alt=""
「Plane Prefab」が、None(Game Object)になっていると思います。
このままの場合、平面の検出はしてくれますが、どこが平面として検出してくれているかわからない状態です。
今回は、平面を確認したいのでPlaneを追加したいと思います!
Planeを作成
Hierarchyで、右クリック>XR>AR Default Plane を選択します!
data:image/s3,"s3://crabby-images/48acf/48acf93fd65933b9b12c9db46b50db3a85629bfc" alt=""
data:image/s3,"s3://crabby-images/48acf/48acf93fd65933b9b12c9db46b50db3a85629bfc" alt=""
AR Default PlaneがHierarchyに配置されたと思います!
次に、Project>AssetsにPrefabsというフォルダを作成し、Prefabsフォルダに作成されたAR Default Planeをドラックします。
下の画像のように、AR Default Planeが青くなっていたらOKです!
data:image/s3,"s3://crabby-images/b697a/b697a5c3fb17e46e56c4b678b15557670a260d2e" alt=""
data:image/s3,"s3://crabby-images/b697a/b697a5c3fb17e46e56c4b678b15557670a260d2e" alt=""
次は、Hierarchyから「AR Default Plane」を一旦削除します。
data:image/s3,"s3://crabby-images/52d79/52d793b52c3abbbdeb95b962d4d4b4171fd758a6" alt=""
data:image/s3,"s3://crabby-images/52d79/52d793b52c3abbbdeb95b962d4d4b4171fd758a6" alt=""
削除ができたら、先ほどPrefabsフォルダに入れた「AR Default Plane」を、AR Session Origin>AR Plane Manager>Plane Prefabにドラックします!
data:image/s3,"s3://crabby-images/dea88/dea88808fcd0856d098d9ed7d9081f60fdfb5fd2" alt=""
data:image/s3,"s3://crabby-images/dea88/dea88808fcd0856d098d9ed7d9081f60fdfb5fd2" alt=""
最終的に、上の写真のようになっていればOKです!
これで平面検出ができるようになりました!
平面に箱を配置する
今はまだ、平面を検出できるようにしただけで、ただ平面にAR Default Planeが表示されるだけです。
次は、平面に箱を配置するということをやっていきたいと思います!
少々、理解が難しいことも含まれますが、とりあえずこうすればいいんだ!!って思っていただけるといいと思います。
AR Raycast Managerの配置
Raycastとは、光線だと認識してもらえればいいと思います!
光線と先ほどのAR Default Planeがぶつかる場所に箱を配置します。
詳しく知りたい方は、Unity公式ページのリンクを参照してみてください!!
AR Session Origin > Add Component > AR Raycast Manager を追加します!
data:image/s3,"s3://crabby-images/fc3e5/fc3e55fc9bc480ae0cde86b53ab19869f93fddb0" alt=""
data:image/s3,"s3://crabby-images/fc3e5/fc3e55fc9bc480ae0cde86b53ab19869f93fddb0" alt=""
下の写真のようになっていればOKです!
data:image/s3,"s3://crabby-images/fe3d2/fe3d29e38dd6c1be4aeb4a0a4e76df474c79c4e7" alt=""
data:image/s3,"s3://crabby-images/fe3d2/fe3d29e38dd6c1be4aeb4a0a4e76df474c79c4e7" alt=""
タップ位置を取得する
次からは、少しコーディングをしていきます。
まずは、Project>AssetsにScriptsフォルダを作成してください。
Scriptsフォルダを作成したら、そこにCreate>C# Scriptを選択し、C#ファイルを作成してください!
C#の名前は、任意に変更してください!(今回は、CubeGeneraterとしてます!)
data:image/s3,"s3://crabby-images/823a3/823a358e60f6ca8a8794eba1374cb174d1f3a8da" alt=""
data:image/s3,"s3://crabby-images/823a3/823a358e60f6ca8a8794eba1374cb174d1f3a8da" alt=""
できたら、下の写真のようになっていると思います!
data:image/s3,"s3://crabby-images/517d8/517d8e5e72184b1720eb0f8c182efec02a94aca1" alt=""
data:image/s3,"s3://crabby-images/517d8/517d8e5e72184b1720eb0f8c182efec02a94aca1" alt=""
作成されたC#ファイルを下のように編集します。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.XR.ARFoundation;
using UnityEngine.XR.ARSubsystems;
public class CubeGenerater : MonoBehaviour
{
// 平面に生成するオブジェクト
[SerializeField] GameObject CubeObject;
// ARRaycastManager
ARRaycastManager raycastManager;
// RaycastとPlaneが衝突した情報を格納
List<ARRaycastHit> hits = new List<ARRaycastHit>();
// Start is called before the first frame update
void Start()
{
// ARRaycastManager格納する
raycastManager = GetComponent<ARRaycastManager>();
}
// Update is called once per frame
void Update()
{
// 画面がタッチされたかチェック
if(Input.touchCount > 0)
{
// タッチ情報を格納
Touch touch = Input.GetTouch(0);
// タッチした位置からRayを飛ばして、Planeにヒットした情報をhitsに格納する
if(raycastManager.Raycast(touch.position, hits, TrackableType.Planes))
{
// Cubeを生成する
Instantiate(CubeObject, hits[0].pose.position, Quaternion.identity);
}
}
}
}
Visual Studioが標準で起動されると思います。Visual Studioで問題なければ、そのまま使ってもらえれば問題ないと思います。
もし、Visual Studio Codeを使用したい場合は、こちらを参考にしてください!
data:image/s3,"s3://crabby-images/cedfb/cedfb42b0e527744e31aaa64e0a504ec5bbd4a56" alt=""
data:image/s3,"s3://crabby-images/cedfb/cedfb42b0e527744e31aaa64e0a504ec5bbd4a56" alt=""
C#ファイルの編集が完了したら、一旦保存してUnityに戻ってください!
次に、AR Session Originに先ほど保存したC#ファイルをドラックしてください!
下の写真のようになればOKです!
data:image/s3,"s3://crabby-images/582db/582dbed0cd5afae5c824fbd6716010a387e07eea" alt=""
data:image/s3,"s3://crabby-images/582db/582dbed0cd5afae5c824fbd6716010a387e07eea" alt=""
このままでは、作成したスクリプトのCube ObjectがNone(Game Object)のままなので、Cubeを選択してあげる必要があります。
まず、CubeをAssets>Prefabsにドラックしてください!
data:image/s3,"s3://crabby-images/f2cec/f2cecf9485a1b4ec2799e3c7ddd32cb209a4176e" alt=""
data:image/s3,"s3://crabby-images/f2cec/f2cecf9485a1b4ec2799e3c7ddd32cb209a4176e" alt=""
Cubeも青くなったと思います。
青くなったらHierarchyから一旦、Cubeを削除します。
削除ができたら、Prefabsに入っているCubeをAR Session Origin>Cube Controller(名前は任意)>Cube Objectにドラックします!
data:image/s3,"s3://crabby-images/38ea3/38ea344e7eb42439668cf775abc3411b798f56b6" alt=""
data:image/s3,"s3://crabby-images/38ea3/38ea344e7eb42439668cf775abc3411b798f56b6" alt=""
これで完成です!!
ビルドして、実機で確認してみましょう!
実際に確認してみる!!
まずは、ビルドしましょう!!
Build Settings>Buildを選択し、生成された「Unity-iPhone.xcodeprojをXcodeで実行する流れです。わからなければ、前回を参考にしてみてください!
data:image/s3,"s3://crabby-images/b13cc/b13cc1075c04fc69cd8eef05b807156b8346dbfd" alt=""
data:image/s3,"s3://crabby-images/b13cc/b13cc1075c04fc69cd8eef05b807156b8346dbfd" alt=""
黄色の板みたいなものが、AR Default Planeと言っていたものです。
地面の一部を平面と認識してくれています。平面に向かってタップをすることで下の画像のように箱が配置されるはずです!
data:image/s3,"s3://crabby-images/5755a/5755a4a690a68ea5cf2e63f6700d13b59e244f56" alt=""
data:image/s3,"s3://crabby-images/5755a/5755a4a690a68ea5cf2e63f6700d13b59e244f56" alt=""
まとめ
今回は、ARで平面を検出し、検出した平面に箱を配置しました。
いくつか聞き慣れない単語は、出てきましたが作業的には簡単だったのではないでしょうか。
学習に使った本はこちら!
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
Amazon Kindle Unlimited でもUnityの本はいっぱいあるんじゃ!!
次回は、箱ではないものを表示してみようと思います!!