Unityのゲーム画面にテキストを表示し、スクリプトから操作する方法を説明します。なお、プログラムからUIオブジェクトを生成してレイアウトを作成するにはUIElementsを使うとよいようですが、ひとまずここでは簡易的な方法として、UnityのGUI画面上からUIオブジェクトを配置していきます。
開発環境
- Unity 2019.4.1f1
目次
Text UIオブジェクトを配置する
まずは、UnityのGUI画面からUIオブジェクトのTextを選択して、配置してみましょう。
data:image/s3,"s3://crabby-images/a7f67/a7f6783052aedea245cc1d057313f066182d7cea" alt=""
UI要素はCanvasの子オブジェクトとして配置されます。Canvasについては以下の記事をご覧ください。
あわせて読みたい
data:image/s3,"s3://crabby-images/472df/472dfdac6477296c3cc2f7509cad30f058103056" alt=""
data:image/s3,"s3://crabby-images/54fa1/54fa105717b4337ae4d85494513253a7c98c2800" alt=""
Canvasの基本的な設定と使い方【Unity】
UnityのCanvasはゲーム画面にGUIを表示させるためのもので、このCanvasの子オブジェクトとしてGUI要素が配置されます。ここでは、Canvasの基本的な設定について説明して...
スクリプトとText UIオブジェクトを連携させる
ゲーム全体を管理する空(カラ)のGameObjectに以下のスクリプトをアタッチさせます。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
public class Manager : MonoBehaviour
{
public Text textUI;
// Start is called before the first frame update
void Start()
{
textUI.text = "Sample Text";
}
// Update is called once per frame
void Update()
{
}
}
スクリプトの中にpublicフィールドを配置すると、Inspector上でも以下のようにそのスクリプトがアタッチされたGameObjectにpublicフィールドが表示されるようになります。
data:image/s3,"s3://crabby-images/643cd/643cd5333b178526c0a3741b8996c894525a981f" alt=""
このText UIにHierarchy上のリンクさせたいText UIオブジェクトをドラッグ・アンド・ドロップすることで、スクリプト上のpublicフィールドに設定したText UIオブジェクトがHierarchy上のTextとリンクするようになります。
ゲームを実行すると、以下のようにスクリプトで設定した「Sample Text」という文字列が表示されました。
data:image/s3,"s3://crabby-images/daa64/daa649c6a1b11f44c4867f6ce22b28227dd5428d" alt=""
これで、スクリプト上からText UIオブジェクトの文字を操作することができるようになりました。
コメント