今回はUnityの2Dゲームで画像をマスキングして、表示したり隠したりしてみます。
はじめに
Unityのバージョンは2021.3.14f1です。
SpriteMaskを利用して画像を表示したり隠したりしてみます。
実装開始
まずはスプライト(画像)を2枚用意して並べ、隠したり表示したりします。
オブジェクト追加
「2DObject」→「Sprites」→「Square」を2つ追加します。それぞれの名前を「BlackBox」と「Internal」にします。
data:image/s3,"s3://crabby-images/8f22c/8f22c836624d4ff8cc750f0e5dd2a806154a4e4d" alt=""
BlackBoxは色を黒にしてスケールを大きくします。
data:image/s3,"s3://crabby-images/acefc/acefcfd0bb409243ceaafaf02ff3b31c3c55b851" alt=""
Internalは色を緑にしてスケールを小さくします。
data:image/s3,"s3://crabby-images/f6ead/f6eadf26d8d26c13a40930cd5dd93ba070d57226" alt=""
「2DObject」→「SpriteMask」を追加します。
data:image/s3,"s3://crabby-images/4b61a/4b61a40e81ec0f2d4dcdaf79b0b55fe684364bdc" alt=""
BlackBoxはMaskInteractionを「Visible OutSide Mask」に、Internalは「Visible Inside Mask」に変更します。
data:image/s3,"s3://crabby-images/5c1e7/5c1e70f31bc480ded2bf3435f9167ee15d8be52d" alt=""
下記スクリプトを作成してSpriteMaskにアタッチします。
using UnityEngine; public class MaskPosition : MonoBehaviour { [SerializeField] private Camera _cam; void Update() { transform.position = (Vector2)_cam.ScreenToWorldPoint(Input.mousePosition); } }
実行してマウスを動かすと下記のような感じに。
data:image/s3,"s3://crabby-images/6892a/6892addd28f02e2d63ad68aef48430f16a5f3b44" alt=""
通常は黒い箱(Balckbox)が表示され、中の画像(Internal)が隠されていますが、SpriteMaskを動かして黒箱の上にかぶせると黒い部分が消えて下の緑色が表示されます。
暗闇を歩くのような感じに
次に、SpriteMaskをinternalの配下に移動し、BlackBoxを画面全体を覆うようにします。下記のような感じですね。
data:image/s3,"s3://crabby-images/0d84f/0d84f9dd47b64ccf7c26eb434d1b00959433465d" alt=""
SpriteMaskのスクリプトを外し、InternalにRigidbody2Dを追加、Gravityを0にして、Movementスクリプトをアタッチします。
Movementスクリプトは下記のように変更します。キー操作で動くようにしています。
using UnityEngine; public class Movement : MonoBehaviour { private float speed = 5.0f; private Rigidbody2D _rb; private Vector2 movement; private void Awake() { _rb = GetComponent<Rigidbody2D>(); } private void Update() { movement.x = Input.GetAxisRaw("Horizontal"); movement.y = Input.GetAxisRaw("Vertical"); _rb.velocity = movement * speed; } }
実行してキー操作すると、暗闇を動くような感じになります。
data:image/s3,"s3://crabby-images/06bee/06bee8683c7cdc94ceb1cb231cf193ff7148d612" alt=""