ワールド空間にキャンバスを配置してみよう。
手順
1.原点にキューブを作成する。
data:image/s3,"s3://crabby-images/5671b/5671bbe6d183ea907ebe295a0f8d59eb1f08e498" alt=""
2.キューブを右クリックしてUI–>TEXTを作成する。
data:image/s3,"s3://crabby-images/8d0cc/8d0cc7c127a170783d17ca52aa758378d33a8af5" alt=""
3.canvasの設定
data:image/s3,"s3://crabby-images/7023f/7023fd48cfb89e4a1c1dd5cb6584fd7aaa4df0f4" alt=""
4.Textの設定
data:image/s3,"s3://crabby-images/99460/99460b01863436cc6189b59bac5cf2f06f1aa94e" alt=""
5.Cubeをプレファブ化し、ヒエラルキーからは削除する
data:image/s3,"s3://crabby-images/e7e09/e7e090ede9b15e0577df7f1de1020f4b96013a7e" alt=""
6.CubeGeneratorスクリプトを以下のように作成
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
public class CubeGenerator : MonoBehaviour
{
public GameObject prefab;
void Start()
{
for(int i = 1; i <= 9; i++) {
for(int j = 1; j <=9; j++) {
GameObject cube = Instantiate(
prefab,
new Vector3(j , 9- i, Random.Range(-10f, 10f)),
Quaternion.identity
);
cube.GetComponent<Renderer>().material.color = Color.cyan;
//子要素の検索GetChildにわたすインデックスはヒエラルキーの並び順の上から0,1,2...
cube.transform.GetChild(0).GetChild(0).GetComponent<Text>().text = i*j + "";
}
}
}
}
7.CreateEmptyから空オブジェクトを作成しCubeGeneratorとリネーム。
その後CubeGeneratorスクリプトをアタッチ。
最後にCubeプレファブを登録する。
data:image/s3,"s3://crabby-images/2a8ef/2a8eff1540517be2e1ed50225d87327d2d37ec18" alt=""
8.カメラの調整。
以下のようにカメラのトランスフォームを調整する。
data:image/s3,"s3://crabby-images/7231d/7231d3acc7483ec0f6d9a7ecf54aa44929bb0c38" alt=""
9.実行してみよう。Cubeがz軸のみランダムに配置されている。
data:image/s3,"s3://crabby-images/30401/30401af64c329627a7c524b5a2616f819af50d88" alt=""
10.CubeControllerスクリプトを以下のように作成する。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class CubeController : MonoBehaviour
{
void Update()
{
Vector3 dist = transform.position;
dist.z = 0;
transform.position = Vector3.Lerp(transform.position, dist, 1.5f * Time.deltaTime);
//transform.position = Vector3.MoveTowards(transform.position, dist, 4f * Time.deltaTime);
}
}
11.プレファブのCubeにアタッチ
data:image/s3,"s3://crabby-images/11b06/11b06f22b9fdc7f45a42d4a1c91a164f576f70f0" alt=""
12.実行してみよう。Lerpの効果によってキレイに所定の場所に収まるのがわかる。
13.コメントアウトされているVector3.MoveTowardsとの動きの違いも確認しておくこと。
コメント