Unity2Dで「カウントダウンのタイマー」を実装していきます。いくつか方法がありますが簡単な方法で作成してみます。
はじめに
Unityのバージョンは2021.3.14f1です。
下記のようなシンプルな形のタイマーを実装していきます。
data:image/s3,"s3://crabby-images/52c84/52c840d5c18ce107a8391c400f966050cfb4edbe" alt=""
分かりやすいようにサイズを大きく作成しています。
実装開始
まずは横バーのタイマーを作成してから円形のタイマーを作成していきます。
UI作成
Hierarchyで右クリックして「UI」→「Image」を追加。
data:image/s3,"s3://crabby-images/6f212/6f21228ae4af036588e3f13ebbfd936be6450785" alt=""
名前を「Timer」にしてSourceImageをSquareに、幅と高さ(WidthとHeight)を変更して下記の様にします。
data:image/s3,"s3://crabby-images/5fde4/5fde4b9fd71421751dd50b9b0d8bfde372acddd3" alt=""
「Timer」配下に「UI」→「Image」を追加。
data:image/s3,"s3://crabby-images/f3646/f3646c6c4351c8ac2aaebdcec8d2ecc66e897e51" alt=""
名前を「Fill」にして色を変更、幅と高さを調整します。
data:image/s3,"s3://crabby-images/25751/2575198c20c4043ecc89c88619aa3536f7acdc47" alt=""
「Image Type」をFilledにして、FillAmountの数字を減らすとバーが減少している風になります。
data:image/s3,"s3://crabby-images/5f4c3/5f4c39b973119d73366e777e2d9b748e9d5f2181" alt=""
以前作成したライフバーと同じような動きですね。
テキストの追加
残り時間を表示するテキストを追加します。「Timer」の配下に「UI」→「Text-TextMeshPro」を追加。
data:image/s3,"s3://crabby-images/ff423/ff423ea4d78a577476f5f915ebffebc78827aae3" alt=""
名前をTimerTextに変更して、FontSizeを調整します。
data:image/s3,"s3://crabby-images/68ccd/68ccd601c266db5459f065e8fd4ebe722d426ca5" alt=""
スクリプト作成
下記スクリプトを作成します。CountTimeは始まりの秒数、Update内で経過時間を引いて残り秒数を算出しています。
using UnityEngine; using UnityEngine.UI; using TMPro; public class Timer : MonoBehaviour { [SerializeField] private Image uiFill; [SerializeField] private TextMeshProUGUI uiText; [SerializeField] private float CountTime; private void Update() { float timer = CountTime - Time.time; int minutes = Mathf.FloorToInt(timer / 60); int seconds = Mathf.FloorToInt(timer % 60); uiFill.fillAmount = Mathf.InverseLerp(0, CountTime, timer); uiText.text = minutes.ToString("00") + ":" + seconds.ToString("00"); } }
Timerにアタッチしてパラメータをセット。
data:image/s3,"s3://crabby-images/fdb0a/fdb0a9e31ed3998d24b9b4feca27944de80ae1a1" alt=""
実行すると下記の様な感じのバー式のタイマーになります。
data:image/s3,"s3://crabby-images/65453/65453044da3909a7173bedee87a803596d0fe3a4" alt=""
円時計式のタイマー
画像を入れ替えて時計式のタイマーにしていきます。SourceImageにCircleをセット。
data:image/s3,"s3://crabby-images/3161b/3161bd87b91532fec74d3ab63ae49b25ab70bf6f" alt=""
imageTypeの「Fill Method」と「Fill Origin」を変更して時計回りに減少するようにセットして完成です。
data:image/s3,"s3://crabby-images/4f50c/4f50ccf3bd5ac5f90d32e4f5394626fe54e92040" alt=""