今回は、Sliderを使ってHPバーの作り方を記述していきます。
HPバーの用意
ヒエラルキーでUI>Sliderをしてスライダーを出します。
data:image/s3,"s3://crabby-images/c7632/c76323ee3d6dfb6ffd5d8da21423b9bdb6d63da5" alt=""
↓
data:image/s3,"s3://crabby-images/0b052/0b052c13d674a139a12d7e9c54e2bc5988a2b3ae" alt=""
設定は任意ですが僕の場合は、Canvasで「Screen Space – Overlay」から「World Space」に変えてHPバーをワールド座標に対応させてます。
皆さんの作るゲームに合うように設定をしてもらっても構いません。
ワールド座標に対応させる場合はScaleで大きさを調節しておきましょう。
data:image/s3,"s3://crabby-images/ede96/ede96a1ec458d82d154b8ef703d33919172c2e10" alt=""
次に、Sliderの子オブジェクトで「Handle Slide Area」があります。
これは不要なので削除してください。
data:image/s3,"s3://crabby-images/1795e/1795e129dacec2be8fb013bba17f8ee4dcf6904c" alt=""
Fill Areaの子オブジェクトのFillでバーの色を変更できるので好きな色にします。
data:image/s3,"s3://crabby-images/59826/59826853a3c16ee9bc3b94d44cb4c8f613d08174" alt=""
SliderのSliderコンポーネントの中にあるValueを動かしてみましょう。
data:image/s3,"s3://crabby-images/83469/834692abf46d7586e739465b2002513c22206cd4" alt=""
data:image/s3,"s3://crabby-images/0a86a/0a86a60329626802e00e9c702d51425462065d1f" alt=""
謎の隙間とHPの余りがありますね。
この問題を解決しましょう。
Fill AreaのRect Transformの「Left」と「Right」を「0」にします。
data:image/s3,"s3://crabby-images/69861/69861a7a89dfd4c8dd2ec369b580b7b6f01bae51" alt=""
次に、Fill Areaの子オブジェクトのFillのRect Transformにある「Width」を「0」にします。
注意:Valueを「0」にした状態でないと「Width」が出ませんので「0」にしておいてからやりましょう。
data:image/s3,"s3://crabby-images/e71bf/e71bfb39d4ce2a55ab16516e1b83ef56b9ac6272" alt=""
これで、謎の隙間とHPの余りの問題が解決します。
data:image/s3,"s3://crabby-images/83ab9/83ab9d9c4c68d42c9530d3091ae941b3e44c8760" alt=""
これで準備完了です。
スクリプトで減るようにする
このスクリプトを書きましょう。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;
public class HPBarScript : MonoBehaviour
{
float HP = 10;
public Slider healthBar;
// Start is called before the first frame update
void Start()
{
}
// Update is called once per frame
void Update()
{
healthBar.value = HP;
if (Input.GetMouseButtonDown(0))
{
HP -= 1;
}
}
}
右クリックをするたびにHPを「1」減らすスクリプトになっています。
書けたら、アタッチしたいオブジェクトにこのスクリプトをアタッチしましょう。
パブリックでスライダーの変数を宣言したのでインスペクターにあるスクリプトの中にSliderを入れます。
data:image/s3,"s3://crabby-images/fd23d/fd23d1e075257f9dcc8e468007c094264f45853a" alt=""
スクリプトでHPを10にしましたので
SliderのSliderコンポーネントにある「Max Value」もそれに合わせます。
data:image/s3,"s3://crabby-images/92e1f/92e1f9ac1e9014b8c46906dfc22c096b4cf164a5" alt=""
実行
これで実行をしてみると
data:image/s3,"s3://crabby-images/c1fc7/c1fc72b582ff8cd98c0594560c7bade7572791d1" alt=""
HPが減るようになりました!
まとめ
いかがでしたでしょうか?
HPバーはゲームでたくさん使うので、作り方は是非覚えておきましょう!
コメント