data:image/s3,"s3://crabby-images/ef2e1/ef2e12fcc393d7cf440a130f2c55dac63ce9d78e" alt=""
画像の縁に簡単にゲージを付けてみます。まずフリー素材サイトなどで背景が透明な画像を用意します。https://www.irasutoya.com/
これをGIMPで開いて、色 -> 色要素 -> チャンネル分解をクリックします。
data:image/s3,"s3://crabby-images/4d075/4d07519001cb1666b28066044d047090fc538d15" alt=""
チャンネル分解で、色モデルをアルファにしてOKを押すと、不透明なところの白いグレースケール画像になります。
data:image/s3,"s3://crabby-images/da543/da543256aefddadf6204cce8eb4baa793ed23d29" alt=""
data:image/s3,"s3://crabby-images/608fc/608fc0fcc3db781bd67fcab08af6d2eba2fe7c25" alt=""
このレイヤーを右クリックして、レイヤーマスクを追加します。
data:image/s3,"s3://crabby-images/7b602/7b6027251ed70fefa5a24050e4b5e9d1313141d4" alt=""
白黒の画像の方をクリックしてコピーし、レイヤーマスクをクリックしてペーストします。イカリのマークで適用します。
data:image/s3,"s3://crabby-images/7474d/7474dbbbdd3bd33472b0333886b77ff9b0b5789f" alt=""
すると、黒い部分が透明になるのでインポートして、元の画像と一緒にUnityにもっていきます。
data:image/s3,"s3://crabby-images/52746/5274630921d5dc5a949aebd2e5f9347944f17929" alt=""
インポートした画像を両方選択して、インスペクタでTexture TypeをスプライトにしてApplyします。
data:image/s3,"s3://crabby-images/1a550/1a55080d03455b0cf56df839360d68aeb82a97a1" alt=""
シーンにCanvasとImageオブジェクトを新規作成して、ImageコンポーネントのSource Imageに元の画像のスプライトをアタッチします。Preserve Aspectでアスペクト比を維持できます。
data:image/s3,"s3://crabby-images/34794/347940c6f8374e6cdeb48b1e7ce5cefc8dc7efff" alt=""
Rect Transformで位置を調整して、中央に大きめに表示しました。
data:image/s3,"s3://crabby-images/7fcc9/7fcc94a3a7ae013589b2133148f80a0b62caa584" alt=""
このImageオブジェクトを複製して、ヒエラルキーウィンドウで上にある方に、白黒のスプライトをアタッチします。
data:image/s3,"s3://crabby-images/401d4/401d48f90936632e0c2019ff96385c53093004d0" alt=""
data:image/s3,"s3://crabby-images/918ec/918ec2be58e1c93713513122e766edae8ae9bcbb" alt=""
こちらはScaleを少し大きめにして、Image TypeをFilledにします。Fill Amountの値を変えると、円形に画像を途切れさせることができるので、画像の縁にゲージが付いたように見えます。
data:image/s3,"s3://crabby-images/c0a26/c0a264eff56d734faa16b085167413041a184a16" alt=""
縁の太さがまちまちですが、簡単に縁にゲージを付けられました。画像によっては綺麗な縁になります。
data:image/s3,"s3://crabby-images/71d95/71d955baf6b294a2301e663215e3efa2c09d88b3" alt=""
data:image/s3,"s3://crabby-images/f3bed/f3bed3bd5d4dca979a756ffe825c98e73ae5ae40" alt=""
後ろの画像だけ見るとこうなります。
data:image/s3,"s3://crabby-images/92a8e/92a8e109a57a949c0dcb2474369f9799f7ba969e" alt=""
Fill Amountの値はスクリプトでも変えられます。
using UnityEngine;
using UnityEngine.UI;
public class GaugeTest : MonoBehaviour
{
Image image;
// Start is called before the first frame update
void Start()
{
image = GetComponent<Image>();
}
// Update is called once per frame
void Update()
{
if (Input.GetMouseButton(0))
{
image.fillAmount -= 0.02f;
}
else
{
image.fillAmount += 0.02f;
}
}
}