今回はUnityでDOTween(HOTween v2)を利用して、画像を動かしたりフェードイン・フェードアウトをしてみます。
はじめに
Unityのバージョンは2021.3.14f1です。
ゲームクリア時に出てくる下記の様なものを作成していきます。
data:image/s3,"s3://crabby-images/3e3af/3e3af28ce347c75fdff2bc64274a38f5e2b4b886" alt=""
DOTweenの追加は下記にて記載しています。
画像アセットの追加
まずはUnityAssetStoreにアクセスして、2DCasualUIHDをマイアセットに追加します。
data:image/s3,"s3://crabby-images/6ffa3/6ffa3768542acda2964ebbe907856d45adc3f5be" alt=""
PackageManagerからDownloadをします。
data:image/s3,"s3://crabby-images/3befa/3befab577aff8374679af057b4bdca7773ac544f" alt=""
Download後に全てをimport。
data:image/s3,"s3://crabby-images/b3cbb/b3cbb93529cc8ddf675ab8c56b103ab4ff8a3ec9" alt=""
これで準備完了です。
実装開始
ここから実際に作成していきます。簡単にUIを作成した後、スクリプトで実装していきます。
UIの作成
Hierarchyで右クリックして、「UI」→「Image」を追加。
data:image/s3,"s3://crabby-images/f5d75/f5d75dc380314961c8258ba601af64681ae5cc99" alt=""
名前をPanelに変更して、幅と高さ、SourceImageを変更して下記の様にします。
data:image/s3,"s3://crabby-images/8892d/8892d181d931469e8b3fa8e176ef01a3fd315dba" alt=""
Panel配下で「UI」→「Image」を追加
data:image/s3,"s3://crabby-images/d03de/d03de2dd8b56d8525b06b669b20d3503aec3b161" alt=""
名前をPanelTitleにして位置や幅、高さを変更、SourceImageとColorを変更。下記の様にします。
data:image/s3,"s3://crabby-images/9b40a/9b40af97683d9b2a95e53c22d1f53472d6d710d5" alt=""
PanelTitleの配下に「UI」→「Text-TextMeshPro」を追加。
data:image/s3,"s3://crabby-images/5c21d/5c21d71528779088548722cb84f16d2132896878" alt=""
テキストを変更して下記の様にします。
data:image/s3,"s3://crabby-images/3f5a3/3f5a3baf26b9b99efb11a87152d22a9f66f99700" alt=""
「Panel」の配下に「UI」→「Canvas」を追加。
data:image/s3,"s3://crabby-images/81266/81266187a4ff2f0567c99105a2d199679e4d3d85" alt=""
名前をStarsに変更し、更にその配下に「UI」→「Image」を追加
data:image/s3,"s3://crabby-images/b43b3/b43b3af4d137ddd1df6006051622b5f78712096f" alt=""
SourceImageを変更して下記の様に配置。
data:image/s3,"s3://crabby-images/32032/32032d2060d779119c4f0c9637c368608b25b7ed" alt=""
コピーして3つ、下記の様に配置します。
data:image/s3,"s3://crabby-images/137df/137dfbad8b6f136942eed4fed9d203e7db52d653" alt=""
これでとりあえず簡単なUIの完成。これをDOTweenを利用して動かしてみます。
スクリプトの作成
まずは下記スクリプトを作成。DOTweenを使わず、パネルを有効/無効を切り替えてみます。
using UnityEngine; public class fade : MonoBehaviour { [SerializeField] private GameObject Panel; private void Update() { if (Input.GetKey(KeyCode.Space)) Panel.SetActive(true); if (Input.GetKey(KeyCode.A)) Panel.SetActive(false); } }
パラメータをセット
data:image/s3,"s3://crabby-images/de703/de703d56aefca3983e13f8e1ebc0104f41aeb53f" alt=""
実行すると下記の様な感じでスペースキーを押すとパネルが有効になります。「パッ」と出てくる感じですね。これをDOTweenを使って動きを付けてみます。
data:image/s3,"s3://crabby-images/ecf97/ecf977ed3e735270982146f3cf9edbe0bf6a89dd" alt=""
スクリプトを下記に変更。
using UnityEngine; using DG.Tweening; public class fade : MonoBehaviour { [SerializeField] private RectTransform rectTransform; private float fadeTime = 0.6f; private float fadePos = 1000f; private void Update() { if (Input.GetKey(KeyCode.Space)) FadeIn(); if (Input.GetKey(KeyCode.A)) FadeOut(); } private void FadeIn() { rectTransform.transform.localPosition = new Vector3(0f, fadePos, 0f); rectTransform.DOAnchorPos(new Vector2(0f, 0f), fadeTime, false); } private void FadeOut() { rectTransform.transform.localPosition = new Vector3(0f, 0f, 0f); rectTransform.DOAnchorPos(new Vector2(0f, fadePos), fadeTime, false); } }
実行すると下記の様な感じ、上からパネルが出てくる動きになります。
data:image/s3,"s3://crabby-images/ce0dd/ce0dd2fdda3a79c61d1bf9af335639e81da38ed5" alt=""
フェードイン・フェードアウト
PanelにCanvasGroupをアタッチ。
data:image/s3,"s3://crabby-images/b65cf/b65cfbf9f43b03445c45275f18289f5aebc0884c" alt=""
スクリプトを下記に変更。
using System.Collections; using System.Collections.Generic; using UnityEngine; using DG.Tweening; public class fade : MonoBehaviour { [SerializeField] private CanvasGroup canvasGroup; [SerializeField] private float fadeTime; private float fadePos = 1000f; private void Update() { if (Input.GetKey(KeyCode.Space)) FadeIn(); if (Input.GetKey(KeyCode.A)) FadeOut(); } private void FadeIn() { canvasGroup.alpha = 0f; canvasGroup.DOFade(1, fadeTime); } private void FadeOut() { canvasGroup.alpha = 1f; canvasGroup.DOFade(0, fadeTime); } }
パラメータをセットします。
data:image/s3,"s3://crabby-images/4bda2/4bda2b2edcfa217dfd2639514281255d89220cc3" alt=""
実行すると下記の様な感じに。
data:image/s3,"s3://crabby-images/92305/92305283af891b04e3c5a23bdd02234ebc0ca18c" alt=""