例えば、UIで画像の上に文字を表示するように作って、それをゴールした時に少しずつ不透明にしていって、表示するようにしたいときのスクリプトの作り方です。
完成動作
作り方
UIを作成
画像の上にテキストが重なるように作成
1.UI→Imageを作成
data:image/s3,"s3://crabby-images/d2067/d206765675b2080f1f5f54910431df5af1ff7728" alt=""
2.Imageの子の要素となるようにTextを作成
data:image/s3,"s3://crabby-images/dab18/dab18652f602195d9e82fce52874c49008ede863" alt=""
※Unityの新しめのバージョンではTextはUI→Legacyの中にあります。
data:image/s3,"s3://crabby-images/4fe5a/4fe5ae0d0f0ccf9f4fa974ae702718fd55aa2b85" alt=""
以下のような状態になる。
data:image/s3,"s3://crabby-images/ceec1/ceec1483a17b352130bf667bbb6385eb44d064e9" alt=""
3.ImageとTextの位置を中央にする。(Pos X,Y,Zを0にする)
data:image/s3,"s3://crabby-images/2f302/2f3020a8a50860c0324684ab14eff910c9343e4b" alt=""
data:image/s3,"s3://crabby-images/38580/38580998913b0186d63769937e5a29f56d5f3dfe" alt=""
4.例としてTextの文字をゴールにし、Alignmentで上下・左右中央寄せにする
data:image/s3,"s3://crabby-images/f5839/f583936a4f3cb500bc7a0f3090c07d8b814e9cb5" alt=""
data:image/s3,"s3://crabby-images/92821/928212459a7495ddddba5bddbfe3a4ecb8632aca" alt=""
5.画面の中央にImageとTextが表示されていることを確認(例なので、実際は端っこでもどこでも良い)
data:image/s3,"s3://crabby-images/f3611/f361189850449b8ebe3fe0a6caf9829e7a89ced7" alt=""
透明度をスクリプトから変更するための準備
1.透明度をまとめて変更したいUIの一番上の親(今回はImage)に”Canvas Group”コンポーネントを追加
data:image/s3,"s3://crabby-images/c2033/c203329164e1a617bc0225a96bb3583002ccc624" alt=""
data:image/s3,"s3://crabby-images/8c427/8c427dbd3e7e42569ea87fc7484697d72ef5d79c" alt=""
※Alphaの値を変えることで透明度を変えることができる。
透明度を変更するスクリプトを作成
1.ChangeAlpha.csという名前のスクリプトを作成して、以下のコードを記載する。
using UnityEngine;
// CanvasGroupコンポーネントがアタッチされていない場合、アタッチ
[RequireComponent(typeof(CanvasGroup))]
public class ChangeAlpha : MonoBehaviour
{
// フェードさせる時間を設定
[SerializeField]
[Tooltip("フェードさせる時間(秒)")]
private float fadeTime=1f;
// 経過時間を取得
private float timer;
// Start is called before the first frame update
void Start()
{
// このゲームオブジェクトのCanvasGroupコンポーネントを取得して、
// alpha値を0(透明)にする。
this.gameObject.GetComponent<CanvasGroup>().alpha = 0;
}
// Update is called once per frame
void Update()
{
// 経過時間を加算
timer += Time.deltaTime;
// 経過時間をfadeTimeで割った値をalphaに入れる
// ※alpha値は1(不透明)が最大。
this.gameObject.GetComponent<CanvasGroup>().alpha = timer / fadeTime;
}
}
スクリプトを”Canvas Group”コンポーネントをアタッチしたGameObjectにアタッチ
1.ChangeAlpha.csをImageにアタッチ
data:image/s3,"s3://crabby-images/44d1c/44d1c63a1de8e4df3d1676f56643ff89e86301e3" alt=""
data:image/s3,"s3://crabby-images/4291e/4291ee0cbdbc5c072eb4d735419df10818e436c4" alt=""
完成
これでゲームを開始すると、少しずつ画像とテキストがフェードインしてくる。
フェードインが完了するまでの時間を変更したい場合は、”Change Alpha”コンポーネントの”Fade Time”を変更する。
コメント