Unityの2Dゲームで「プレイヤーの上にダメージを表示」していきます。
敵の攻撃が当たった時などに、プレイヤーの上に数字を表示する感じです。今回は「画面に数字を表示」する部分の実装なので、敵の攻撃やプレイヤーのライフ部分は無いです。
はじめに
Unityのバージョンは2021.3.14f1です。
下記のように、プレイヤーの上にダメージ数を表示してみます。
data:image/s3,"s3://crabby-images/3783d/3783d45b7679633e0c728a517be713f806688ef6" alt=""
実装開始
まずはキー操作で動くプレイヤーを作成、その後ダメージの実装をしていきます。
プレイヤーの作成
「Create Empty」で空のオブジェクトを2つ追加。PlayerとGroundに名前を変更します。
data:image/s3,"s3://crabby-images/030a3/030a3164af9af98f1fb7dc22f5462392741e05b8" alt=""
それぞれ、下記のように設定します。
data:image/s3,"s3://crabby-images/7109e/7109e69f5fc2c1ff398eb17a6a07c05ba9dd38bd" alt=""
PlayerMoveのスクリプトは下記の様な感じ。
using UnityEngine; public class PlayerMove : MonoBehaviour { private float PlayerSpeed = 0.5f; private Rigidbody2D _rigidbody; void Start() { _rigidbody = GetComponent<Rigidbody2D>(); } void Update() { float InputX = Input.GetAxisRaw("Horizontal"); _rigidbody.velocity = new Vector2(InputX * PlayerSpeed, 0); } }
下記が参考記事になります。
実行してみて、地面の上をプレイヤーがキー操作で動けばOK
ダメージテキストの追加
「UI」→「Legacy」→「Text」を追加。
data:image/s3,"s3://crabby-images/7b1ff/7b1ffddda4d2805cf0f07d13eb94da277242e6df" alt=""
Canvasのレンダーモードをカメラに変更し、カメラをセット。
data:image/s3,"s3://crabby-images/c49ba/c49baeed9a72279449f3ec1f394eaef046ab985b" alt=""
Textの幅、高さ、フォントサイズを調整。テキストは仮の値を入れておきます。
data:image/s3,"s3://crabby-images/c610d/c610de3f19e9b7c4a842f2ceb39dd78f09c2c6de" alt=""
下記の様な感じですね。
data:image/s3,"s3://crabby-images/c0903/c0903582355ce68c44c6d8036c9c01f23358cf21" alt=""
ダメージのスクリプト作成
Damageと言う名前で新規スクリプトをアタッチ、スクリプトの中身は下記です。
using UnityEngine; using UnityEngine.UI; public class Damage : MonoBehaviour { private float _displaytime = 0.4f; private float _timer; private Text _txt; private void Awake() { _txt = GetComponent<Text>(); } void Update() { _timer += Time.deltaTime; if (_timer > _displaytime) Destroy(gameObject); } public void SetDamageText(int value) { _txt.text = value.ToString(); } }
一定時間表示したらオブジェクトを削除、ダメージ量はSetDamageTextでセットします。
オブジェクト名をDamageに変更して、プレハブ化しておきます。
data:image/s3,"s3://crabby-images/93b89/93b8907139c4289565f05304504ae0db37e90961" alt=""
プレハブを出したり消したりしてダメージを表示します。
プレハブ管理を追加
次にダメージのプレハブを呼び出すマネージャを追加します。空オブジェクトを追加してDamageManagerと言う名前に変更します。
data:image/s3,"s3://crabby-images/1f39d/1f39d411cf62e95082943301cbd12e0f4af122b9" alt=""
DamageManagerと言う名前で新規スクリプトを作成、スクリプトの中身は下記です。
using UnityEngine; public class DamageManager : MonoBehaviour { [SerializeField] private GameObject _damageobj; [SerializeField] private Canvas _canvas; [SerializeField] private Transform _target; public void TakeDamage(int damageval) { Vector2 pos = new Vector2(_target.position.x, _target.position.y + 1.0f); Damage damageIns = Instantiate(_damageobj, pos, Quaternion.identity, _canvas.transform).GetComponent<Damage>(); damageIns.SetDamageText(damageval); } }
指定位置にプレハブをインスタンス化して、ダメージ量をセットしているという感じです。
アタッチして各変数をセットします。
data:image/s3,"s3://crabby-images/5aee6/5aee680c03a744da599fd9dbc012d8e158257d5c" alt=""
ダメージボタンの追加
今回はボタンを押したらダメージを食らうようにしてみます。「UI」→「Legacy」→「Button」を追加。
data:image/s3,"s3://crabby-images/681e3/681e36b3113d26d7cf84983cf09fcb1aaa62cf6d" alt=""
ボタンクリック時に呼び出します。
data:image/s3,"s3://crabby-images/e6239/e6239128f1ca91a15f7cba9c3bb5688d423b42bc" alt=""
ボタンを押してプレイヤーの上にダメージが表示されたらOK。
data:image/s3,"s3://crabby-images/8dbc7/8dbc71af82d093446441c31ae908c86c36f461fc" alt=""
このままだと表示して消すだけなので、少しスクリプトを変更。
using UnityEngine; using UnityEngine.UI; public class Damage : MonoBehaviour { private float _displaytime = 0.4f; private float _timer; private Text _txt; private Vector3 pos; private void Awake() { _txt = GetComponent<Text>(); pos = transform.position; } void Update() { _timer += Time.deltaTime; if (_timer > _displaytime) Destroy(gameObject); pos.y += 0.01f; transform.position = pos; } public void SetDamageText(int value) { _txt.text = value.ToString(); } }
表示されてから数字が上昇して消えるという感じです。