今回はUnity2Dゲームで「ブロックが壊れる(崩れる)エフェクト」を実装していきます。
アニメーションを利用する方法もありますが、ParticleSystemを利用してみます。
はじめに
Unityのバージョンは2021.3.14f1です。
ParticleSystemは下記の記事でも簡単に紹介しています。
実装開始
プレイヤーを作成後、ブロックを作成します。
地面とプレイヤーの作成
「2DObject」→「Sprites」→「Square」を2つ追加。
一つをPlayerにしてBoxCollider2D、Rigidbody2Dをアタッチ。PlayerMoveと言う名前でスクリプトもアタッチしておきます。
data:image/s3,"s3://crabby-images/d82e1/d82e1f8f82eb077f14e4d7f1b28e993413a13cad" alt=""
もう一つはGroundにしてLayerを変更、BoxCollider2Dをアタッチ。下記の様なゲーム画面にします。
data:image/s3,"s3://crabby-images/f932a/f932abbf69f5320f02ed364e6659da7adc27e33a" alt=""
スクリプトを下記に変更してプレイヤーを動くようにします。
using UnityEngine; public class PlayerMove : MonoBehaviour { [SerializeField] private LayerMask _groundLayer; private float _PlayerSpeed = 10.0f; private float _jumpPower = 10.0f; private Rigidbody2D _rb; void Start() { _rb = GetComponent<Rigidbody2D>(); } void Update() { float InputX = Input.GetAxisRaw("Horizontal"); if (Input.GetKey(KeyCode.Space) && isGrounded()) _rb.velocity = new Vector2(_rb.velocity.x, _jumpPower); _rb.velocity = new Vector2(InputX * _PlayerSpeed, _rb.velocity.y); } private bool isGrounded() { RaycastHit2D raycastHit = Physics2D.Raycast(transform.position, Vector2.down, 0.6f, _groundLayer); return raycastHit.collider != null; } }
PlayerMoveスクリプトのパラメータをセット。
data:image/s3,"s3://crabby-images/27288/272881275e817bf36d926d0b050ad7d62260e8fc" alt=""
実行すると下記の様に左右に動き、スペースキーでジャンプできます。
data:image/s3,"s3://crabby-images/7cae6/7cae6d78887d5d3d7a0a775c5cebaf01e5aea0ed" alt=""
この地面とプレイヤー部分は下記記事に詳しく書いてあります。
ブロックの作成
「2DObject」→「Sprites」→「Square」を追加。
data:image/s3,"s3://crabby-images/86b66/86b66fa6aa690e2b1e288e6a71c789fb69cdf4d2" alt=""
名前をBoxにして、位置と色を変更しておきます。
data:image/s3,"s3://crabby-images/05bbe/05bbe089c49b55e91398f199c5f4414787cf6d5f" alt=""
BoxCollider2DをアタッチしisTriggerにチェック、BreakBoxと言う名前でスクリプトをアタッチします。
data:image/s3,"s3://crabby-images/b041f/b041f23035b40ac783d9fdcd07924545d04c9945" alt=""
スクリプトを下記に変更。
using UnityEngine; public class BreakBox : MonoBehaviour { private void OnTriggerEnter2D(Collider2D col) { Destroy(gameObject); } }
実行すると、下記の様にぶつかるとブロックが消えます。
data:image/s3,"s3://crabby-images/648e9/648e9bfd6bda45aca497dca946fc93036c839542" alt=""
これに破壊したようなエフェクトを追加してみます。
Particle System
Boxの配下に「Effects」→「Particle System」を追加。
data:image/s3,"s3://crabby-images/a9308/a9308830426ab86fde5077af364844efa79ecd0c" alt=""
上向きにエフェクトを出すので、RotationのXを-90にします。
data:image/s3,"s3://crabby-images/acc8b/acc8b8905076cb60cb8879eb8a4f61c807ba77f2" alt=""
Projectフォルダ内にMaterialを新規で作成。
data:image/s3,"s3://crabby-images/87cab/87cab85a36bc89cc03cf371eaface6ce04dee60a" alt=""
ShaderをParticlesにして、ブロックと同じ色に変更します。
data:image/s3,"s3://crabby-images/1d78d/1d78d0d8caa0027e7f271ab86cfbc5635b5c39d6" alt=""
Particle SystemのRendererのMaterialを作成したマテリアルに変更。
data:image/s3,"s3://crabby-images/23049/2304922fc47a27bdaf1f3080b80032a6bef5b996" alt=""
ParticleSystemのDuration、StartLifetime、StartSize、GravityModifierなどを変更して壊れて広がる感じにします。
data:image/s3,"s3://crabby-images/eaa9b/eaa9b07a04ee91b706fc4a54a9af1b9a5d66bfdc" alt=""
スクリプトを下記に変更。
using System.Collections; using UnityEngine; public class BreakBox : MonoBehaviour { [SerializeField] ParticleSystem _particle; private SpriteRenderer _rend; private void Awake() { _rend = GetComponent<SpriteRenderer>(); } private void OnTriggerEnter2D(Collider2D col) { StartCoroutine(BoxDest()); } private IEnumerator BoxDest() { _rend.enabled = false; _particle.Play(); yield return new WaitForSeconds(_particle.main.startLifetime.constantMax); Destroy(gameObject); } }
下記の様な感じになります。
data:image/s3,"s3://crabby-images/e942c/e942cb69e019c016e16be81eb0ada7bf77ae510f" alt=""
この方法が最適かどうかは少し疑問ですが、こんな方法もあるって感じですね。箱を壊すだけでなく、Particle Systemは結構いろんなことに使えそうな感じですな。