Unityで導火線のようなエフェクトを実装してみます。「ParticleSystem」を利用して簡単に実装していきます。
はじめに
「Unity 2022.3.14f1」ヴァージョンで作成しています。以前作成したカウントダウンのタイマーを改造して、ParticleSystemでエフェクトを追加してみます。
まずは横バーのカウントダウンタイマーを作成します。関連記事の下記部分までですね。
data:image/s3,"s3://crabby-images/fdb0a/fdb0a9e31ed3998d24b9b4feca27944de80ae1a1" alt=""
data:image/s3,"s3://crabby-images/65453/65453044da3909a7173bedee87a803596d0fe3a4" alt=""
実装開始
作成した横バーのカウントダウンタイマーを変更していきます。まずはバーを細くするので、TimerとFillの幅を変更します。
data:image/s3,"s3://crabby-images/4762b/4762bce8fd708e131c178603ac3b6ecbcbd3f0cc" alt=""
下記のように細長くなればOKです。TimerTextは消しておきます。
data:image/s3,"s3://crabby-images/ff4e1/ff4e1cf9cf9030ea6df5924912d9a41331f7a6d6" alt=""
ParticleSystemの追加
Fillの配下に「Effects」→「ParticleSystem」を追加します。
data:image/s3,"s3://crabby-images/6e61b/6e61b0b0a587b609f9ed9f3743afefea3e751500" alt=""
ParticleSystemで色や速度、サイズなどを変更します。
data:image/s3,"s3://crabby-images/00171/0017141d3805451631ff414ed09b62d67bb00a09" alt=""
Shapeは半円上にします。
data:image/s3,"s3://crabby-images/2d769/2d7693751bf573ee06184314bb24ec3da89e5181" alt=""
Rendererで「Order in Layer」を変更して手前に表示します。
data:image/s3,"s3://crabby-images/9151f/9151f9797ac151981fbefd9f0405722ec5e841ac" alt=""
実際にシーン画面で再生してみていい感じになるように調整します。個人的にはParticleSystem、Emission、Shape、Rendererで調整して、ほかの項目は触らないことが多いです。
スクリプトを作成
スクリプトを下記に変更します。バーの進行具合に合わせてエフェクト位置も変更しています。サンプルなのでベタ打ちです。実際にはオブジェクト位置などから算出する方が良いです。
using UnityEngine; using UnityEngine.UI; public class Timer : MonoBehaviour { [SerializeField] private Image uiFill; [SerializeField] private float CountTime; [SerializeField] private RectTransform particleTransform; [SerializeField] private ParticleSystem particlesystem; private void Start() { particlesystem.Play(); } 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); ParticlePosChange(uiFill.fillAmount); } private void ParticlePosChange(float amount) { float x = (amount * 480) - 240; particleTransform.localPosition = new Vector3(x, 0, 0); } }
パラメータをセットします。
data:image/s3,"s3://crabby-images/4b367/4b367168139069d547f46b3635f59fd4274643e2" alt=""
実行してみると下記のような感じになります。
data:image/s3,"s3://crabby-images/da25d/da25d998987ffe612d3314cbffca53d357abc9a0" alt=""
「ParticleSystem」については下記でも記事に書いてます。DOTweenを利用したアニメーションやParticleSystemを利用することで見た目(UI)を簡単に変更できますね。