スキルを使用した時のスキルゲージやダメージを食らったり回復したりした時に増減するHPゲージ。
これらのゲージバーを一工夫するとゲームの見栄えはよくなると思います。
今回は、そんなゲージバーの増減をスームーズにさせる方法を紹介していきたいと思います。
ゲージバーを用意
まずはゲージバーを作っていきましょう。
ヒエラルキーウィンドウで右クリック>UI>Sliderでスライダーを生成します。
data:image/s3,"s3://crabby-images/60ec9/60ec9270c744afd695fafc51e80cd777373152c9" alt=""
data:image/s3,"s3://crabby-images/8bab8/8bab85280cee79baf5e4c02d6b6d679a9bea9298" alt=""
次にスクリーンサイズに合わせるためにCanvasで「Render Mode」を「Screen Space-Overlay」にします。
data:image/s3,"s3://crabby-images/c30eb/c30eb74d16da4a2d47d235477064e0b83d729dc3" alt=""
スライダーにある「Handle Slide Area」はいらないので消しておきましょう。
data:image/s3,"s3://crabby-images/481fc/481fc0a323f90bbc2983f9bcc26999dab7e85deb" alt=""
ここで「Slider」の中の「Value」を動かしてみましょう。
data:image/s3,"s3://crabby-images/70dca/70dca7bc1e1d7ee54bc2f3d4702597f23ffd1523" alt=""
「Value」を最大値にしても空白ができてしまい、最小値にしてもゲージが残っています。
これらを直していきましょう。
Fill Areaのインスペクターにある「Rect Transform」の「Left」と「Right」を共に「0」にします。
data:image/s3,"s3://crabby-images/791ad/791ad61bd0e29ba70c423456d06225889d07778e" alt=""
次にFillのインスペクターの「Rect Transform」の「Width」の値も「0」にしましょう。
data:image/s3,"s3://crabby-images/1fa94/1fa94e831c63d0da1802d0978af61b2366f17ea6" alt=""
これでまた「Value」を動かしてみますと。
これでゲージバーは用意ができました。
ゲージバーのプログラム
それではプログラムコードを書いていきましょう。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
public class SmoothSlider : MonoBehaviour
{
[SerializeField] Slider DashGage;
public float maxDashPoint = 5;
float dashPoint;
float currentVelocity = 0;
void Start()
{
dashPoint = maxDashPoint;
DashGage.maxValue = maxDashPoint;
DashGage.value = maxDashPoint;
}
void Update()
{
float currentDashPT = Mathf.SmoothDamp(DashGage.value, dashPoint, ref currentVelocity, 10 * Time.deltaTime);
DashGage.value = currentDashPT;
if (Input.GetKeyDown(KeyCode.E) && dashPoint < maxDashPoint)
{
dashPoint++;
}
else if (Input.GetKeyDown(KeyCode.Q) && dashPoint > 0)
{
dashPoint--;
}
}
}
これで「E」でゲージが増えて「Q」でゲージが減ります。
このスクリプトを適当なオブジェクトにアタッチします。
data:image/s3,"s3://crabby-images/a7fd4/a7fd4d97687caebb35342a5e2fb90d82c3b19f07" alt=""
「Dash Gage」の中に「Gage」を入れます。
data:image/s3,"s3://crabby-images/cc017/cc017f07783fc1a985b83045eb47075d259b56ef" alt=""
これで実行をしてみますと。
完成です!
プログラムの重要ポイント
今回のプログラムで重要な部分は、ここ
float currentDashPT = Mathf.SmoothDamp(DashGage.value, dashPoint, ref currentVelocity, 10 * Time.deltaTime);
DashGage.value = currentDashPT;
Mathf.SmoothDamp(現在値, 目標値,現在速度を格納する変数, 目標値までの変化時間);
というような引数を入れて、それらを計算したものをゲージの「Value」に反映しています。
まとめ
いかがだったでしょうか?
滑らかなゲージを是非活用してみてください!
コメント