スタート画面でよく点滅するテキストがありますよね。
今回は、その点滅テキストの作り方を紹介していきたいと思います。
イメージ図↓
data:image/s3,"s3://crabby-images/2bbc4/2bbc48b41f5f9c4e924c363f2afa9814856881ef" alt=""
準備
まずは、テキストを用意
ヒエラルキーで右クリック>UI>Text-TextMeshPro
data:image/s3,"s3://crabby-images/e7255/e7255d2dedc0feaf043a8486463794d09bcf273b" alt=""
普通のTextを使う場合はヒエラルキーで右クリック>UI>Legacy>Text
data:image/s3,"s3://crabby-images/0a887/0a88785379e9509cc26999c025f48ebfa4ce4854" alt=""
画面サイズに適応させるために、「Canvas Scaler」の「UI Scale Mode」を「Scale With Screen Size」に変更しておきましょう。
data:image/s3,"s3://crabby-images/bcd2c/bcd2ccc3e77c38aafbb3f7a7ceed89f11b02e2db" alt=""
あとは色や位置を調整すれば準備は完了
data:image/s3,"s3://crabby-images/e281e/e281e976f4f421572a3034b51cd2c1825425ba9e" alt=""
点滅させるスクリプト
TextMeshPro用のソースコード
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using TMPro;
public class 点滅 : MonoBehaviour
{
float speed = 1.0f;
float time;
TMP_Text text;
void Start()
{
text = gameObject.GetComponent<TMP_Text>();
}
// Update is called once per frame
void Update()
{
text.color = GetAlphaColor(text.color);
}
Color GetAlphaColor(Color color)
{
time += Time.deltaTime * 3.5f * speed;
color.a = Mathf.Sin(time);
return color;
}
普通のText用のソースコード
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
public class 点滅普通 : MonoBehaviour
{
float time;
float speed = 1.0f;
Text text;
void Start()
{
text = gameObject.GetComponent<Text>();
}
void Update()
{
text.color = GetAlphaColor(text.color);
}
Color GetAlphaColor(Color color)
{
time += Time.deltaTime * 3.5f * speed;
color.a = Mathf.Sin(time);
return color;
}
}
このソースコードをTextにアタッチします。
data:image/s3,"s3://crabby-images/0316c/0316ce2cdfceb91684b9cf99303fbc969a293035" alt=""
これで実行してみましょう。
できました!
スクリプトの簡単な説明
重要なのはこの関数
Color GetAlphaColor(Color color)
{
time += Time.deltaTime * 3.5f * speed;
color.a = Mathf.Sin(time);
return color;
}
ここでは、テキストのアルファ値をMathF.Sin関数を使って周期的に「0→1」「1→0」をさせています。
これによりテキストが透明になったりもとにもだったりが可能になります。
そして、その値を返り値としてUpdateのtext.colorに返しているわけですね。
まとめ
以外にも簡単にできましたね。
この機能をキャラクターの点滅にも使ってみたいです。
コメント