メインコンテンツへスキップ
【超簡単】unity2dで衝突時に画像を切り替える方法をわかりやすく解説
  1. Posts/

【超簡単】unity2dで衝突時に画像を切り替える方法をわかりやすく解説

loading · loading ·

Unityで画像の切り替え方法を探している方向け。

例えばプレイヤーが爆弾に触れた時に爆弾の画像を爆発した画像に切り替えるような感じです。

コピペできるようにコード付きで本記事にてわかりやすく解説します。

この記事は以下のような方を対象者としています。

  • ゲームアプリ開発に興味がある方
  • ゲームアプリを個人開発している方
  • Unityで画像の切り替え方法がわからない方

Unity2Dでの画像切り替えの参考例
#

まずはこちらのgif画像をご覧ください。

Alt text

キャラクターが爆弾の画像に衝突した時に、爆発後の画像に切り替わっています。

こちらのやり方を本記事にて詳細に説明していきたいと思います。

Alt text
また今回参考例として使うアプリは、先日開発したJumping Quest(ジャンピング クエスト)という2Dゲームアプリを使って説明していきます。

小さいドット絵調のウサギがジャンプひとつで様々な世界を冒険するというコンセプトのゲームです。

ダウンロードして遊んでいただけると泣いて喜びます!

1.画像切り替え用のSpriteを用意する
#

まずは画像を表示するためのSpriteを生成しましょう。

Spriteとは簡単に言うとUnity2Dで使われる画像データです。

まずは添付画像のようにGameObject->2D Object->Sprites->Squareを選択しましょう。

Alt text

するとゲーム画面上に白い四角の画像が表示されます。

Alt text

2.Spriteに衝突できるようRigidbody2DとBoxCollider2Dを設定する
#

この辺りは本題にあまり関係がないので簡潔に説明します。

Rigidbody2DをSpriteにセットすることで物理挙動がつけられるようになります。

BoxCollider2Dはオブジェクトに衝突ができるようになります。

また、今回はキャラが爆弾の絵にぶつかっても爆弾自体の位置は動かしたくないので下記添付画像の通り値をセットします。

Alt text

gravity(重力)を0にすることでオブジェクトが落下しないようにできます。

また、Freeze Position(位置固定)/Freeze Rotation(回転固定)でオブジェクトの位置や回転を制御できます。

3.ImageReplaceスクリプトを作成する
#

続いて本題の画像切り替え用のスクリプトを作成します

先ほど作成したSpriteをクリックし添付画像の通りimageReplace.csファイルを作成&追加しましょう。

Alt text

そしてこちらのスクリプトをコピペしてください。

  using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.UI;

public class bombController : MonoBehaviour
{
    // デフォルトの画像(爆弾の画像)
    public Sprite defaultImage;
    // デフォルトの画像(爆発後の画像)
    public Sprite explodeImage;
    // 画像描画用のコンポーネント
    SpriteRenderer sr;

    void Start() {
        // SpriteのSpriteRendererコンポーネントを取得
        sr = gameObject.GetComponent<SpriteRenderer>();
    }

    // Playerタグがついたオブジェクトと衝突した時に処理
    void OnCollisionEnter2D(Collision2D coll) {
        if (coll.collider.tag == "Player") {
            // デフォルトの画像を爆発後の画像に切り替える
            sr.sprite = explodeImage;
        } 
    }
}

こちらのスクリプトにより、元画像の描画コンポーネントを取得し、爆発後の画像に置き換えることができます。

スクリプト作成後は保存を忘れないようにしましょう。

4.元画像と切り替え用画像をSpriteにセットする
#

続いて先ほど作成したimageReplaceファイルにdefaultImageとexplodeImageの欄が追加されているのを確認しましょう。

もし追加されていなければ、ファイルの保存が失敗しているか誤記がある可能性があります。

追加されているのが確認できたら、それぞれ爆弾の画像と爆発後の画像をドラッグ&ドロップでセットします。

Alt text

これで完了です。

さいごに
#

ここまでお読みいただきありがとうございました。
私のブログ記事を読んでいる方の中には海外転職・海外移住への興味がある方もいらっしゃるかと思います。

私自身ダナンで働き始めて7年目になりますが、海外就職を実現するために大事なのは英語力と開発現場で働いた経験だと感じました。

もし今後海外移住・海外就職を本気で実現させたい方はぜひこれらのサービスを活用してみてください。

レアジョブ - 実務で使える英語力を身につけよう
#

レアジョブ英会話は英会話力の向上に特化したサービスです。 私の友人もレアジョブを通じて0から学習を続け、現在はベトナム人のエンジニアとも英語でコミュニケーションが取れるレベルまで英会話力を伸ばすことができました。

レアジョブが選ばれる理由は多岐にわたりますが、主な理由としては下記3点が考えられます。

  • 優秀な講師陣:公用語が英語であるフィリピン人の方が講師となり、生きた英語を身につけることができる
  • 豊富な教材: 5,000以上の教材を提供しており、学習者のレベルや目的に応じて最適な教材を選べます。
  • 安心のサポート体制:初心者でも安心して始められるように、日本人カウンセラーが学習のサポートをしてくれます。

海外移住計画の第一歩として、スピーキング力を身につけたいと考えている方は、ぜひこちらの無料体験を試してみてはいかがでしょうか。

Related

【個人開発者必見】ゲーム開発に役立つおすすめツール3選
loading · loading
【ベトナム株式投資】SSI証券口座開設のやり方をわかりやすく解説
loading · loading
【ダナン】コロナが再流行後の生活への4つの変化とは
loading · loading