目次
はじめに
PS4 のゲームプレイ中にトロフィーを獲得すると、画面上部に通知の演出が走ります。今回はその演出を DOTween を使って作ってみます。
data:image/s3,"s3://crabby-images/a3fc7/a3fc7f95ff33852c30ed70aeb9a880f3da50cdd9" alt="PS4『Marvel's Spider-Man』"
演出の完成はこのような感じになります。
data:image/s3,"s3://crabby-images/01259/01259e0cd6390dc8c8797f2ed9b5b87a573b7bee" alt="トロフィー演出"
バージョン情報
Unity 2020.2.0f1
DOTween (HOTween v2) Version 1.2.420
DOTween とは?
DOTween は移動系のアニメーション(イージング)を簡単に実装できるアセットです。
data:image/s3,"s3://crabby-images/64a6c/64a6ca86155dc8d133cdc3ad08983b81f1b155a2" alt="DOTween Asset Store"
Asset Store から無料版をダウンロード可能です。
DOTween Pro という有料版もありますが、機能的には無料版でも十分です。
実際に演出を作ってみる
事前準備
ここからは DOTween を使って演出を作っていきます。
事前準備として、Unity に DOTween アセットをインポートします。
data:image/s3,"s3://crabby-images/46bfc/46bfc69a854caafa7eff7de120e34807eadf2a88" alt="DOTween アセットのインポート"
UI の作成
UIを表示するための Canvas を用意します。
Hierarchy ビューで [ + ] > [ UI ] > [ Canvas ] から Canvas を作成します。
data:image/s3,"s3://crabby-images/8659c/8659c5f7a5d2f52b95b57005aa5d926e27e879ad" alt="Canvas を作成"
作成した Canvas の子オブジェクトに、通知 UI 用のルートオブジェクトを用意します。Canvas を右クリックして Create Empty から GameObject を作成します。
作成した GameObject の名前を「Notification」に変更しておきます。
data:image/s3,"s3://crabby-images/c8dc5/c8dc5feb83a6fe9512e9a82cf0bd8c4d3a54e5ce" alt="GameObject を作成"
Notification オブジェクトの Rect Transform を変更します。
通知 UI は画面左上から表示するため、アンカーを左上に設定し、Position も 0 にします。
data:image/s3,"s3://crabby-images/9cd89/9cd8904b0b0f7f08b9a43154fce9898991fa2a36" alt="Notification オブジェクトの Rect Transform を変更"
Notification オブジェクトの子に Image オブジェクト、その子に Text オブジェクトを作成します。また Image オブジェクトの名前を「NotifyUI」に変更します。
data:image/s3,"s3://crabby-images/7fee9/7fee99238508a941ec14bf0b5bf0a0abb5d2e9bb" alt="Image オブジェクト、Text オブジェクトを作成"
通知UI 作成のため、各 Inspector 情報を変更します。
「Position」X: -700, Y: -200, Z: 0
「Width」600
「Height」150
「Pivot」X: 0, Y: 0.5
「Component」Canvas Group を追加
data:image/s3,"s3://crabby-images/d3bf7/d3bf720015b52266d27a29c1364c92b62bb522c0" alt="NotifyUI の Inspector 情報を変更"
「Height」100
「Text」トロフィーを獲得しました!\n◯◯◯◯◯◯
「Font Size」36
「Alignment」left, center
data:image/s3,"s3://crabby-images/d1878/d1878b10eeb9703f0eedd30514f84d3725d698b8" alt="Text の Inspector 情報を変更"
変更が完了すると、以下のような見た目の UI になっているかと思います。
これで UI の準備は完了です。
data:image/s3,"s3://crabby-images/da12c/da12c00c31da7c15c393598a9d3d00bf3f1627e6" alt="UI作成の準備完了"
コードの実装
通知演出用クラスであるNotificationController.cs
を作成します。
using UnityEngine;
using DG.Tweening;
public class NotificationController : MonoBehaviour
{
private static readonly Vector3 INIT_POS = new Vector3(-700f, -200f, 0f);
private static readonly float MOVE_TIME = 0.5f;
private static readonly float INTERVAL_TIME = 2.5f;
private static readonly float FADE_TIME = 0.7f;
[SerializeField]
private CanvasGroup m_CanvasGroup;
private Sequence m_Sequence;
void Update()
{
// キーボードの「スペース」キーを押したら演出再生
if (Input.GetKeyDown(KeyCode.Space))
{
PlayNotification();
}
}
private void PlayNotification()
{
m_Sequence?.Kill();
m_Sequence = DOTween.Sequence()
.OnStart(() =>
{
m_CanvasGroup.transform.localPosition = INIT_POS;
m_CanvasGroup.alpha = 1f;
})
.Append(m_CanvasGroup.transform.DOLocalMoveX(0, MOVE_TIME).SetEase(Ease.OutQuart)) // 左からスライドイン
.AppendInterval(INTERVAL_TIME) // 待機時間
.Append(m_CanvasGroup.DOFade(0f, FADE_TIME)); // フェードアウト
m_Sequence.Play();
}
}
作成したNotificationController.cs
を「Notification」オブジェクトにアタッチし、「Canvas Group」に「NotifyUI」オブジェクトの Canvas Group をセットします。
data:image/s3,"s3://crabby-images/506b4/506b4b5cca145c571a5a11e0d56e41930f70b992" alt="NotificationController クラスの設定"
これで実装は完了です。
演出の作成完了
Unity を実行して「スペース」キーを押すと演出が再生されるかと思います。
data:image/s3,"s3://crabby-images/d90db/d90db7e8c69af3d0b5408695c5c0af2aa50a3234" alt="notification gif"
Game ビューの Aspect は「1920 × 1080」に設定しています。
data:image/s3,"s3://crabby-images/0a030/0a03048e3f3c49be73208be846455b2287d26ac6" alt="Game ビューの Aspect"
関連記事