今回はUnityでトップダウン式2Dゲームを作成する際に使えそうな、上下左右の移動アニメーション作成していきます。
はじめに
Unityのバージョンは2021.3.14f1で作成しています。
下記のように上下左右に移動するときのアニメーションを実装していきます。
data:image/s3,"s3://crabby-images/c9c44/c9c442794aa94788af4773720659ca3e43a3a691" alt=""
事前準備
まずはアセットストアから素材を入手。
data:image/s3,"s3://crabby-images/3b298/3b2987c2b1ce044eb4e773816641af34e077b8ac" alt=""
dileフォルダとwalkフォルダを選択してインポートしておきます。
data:image/s3,"s3://crabby-images/0abab/0ababc68cf70f886252f79c527c6215a77ec1195" alt=""
インポートした画像をすべて選択して、「PixelsPerUnit」を10に変更しておきます。
data:image/s3,"s3://crabby-images/63baa/63baa17cc4dc3eff39b3e9588474e130f170fad2" alt=""
実装開始
ここから実際に作成していきます。
プレイヤーの作成
まずは後ろ向きの画像をSceneにドラッグアンドドロップします。
data:image/s3,"s3://crabby-images/74369/74369e0e8082cc8c75a4dd69bb5b6716bb7fc895" alt=""
名前をPlayerに変更して、AddComponentから「Animator」を追加しておきます。
data:image/s3,"s3://crabby-images/15e8f/15e8fa143a2635bc0c30633961c6eb8ea4596671" alt=""
Assetsフォルダ内で右クリック、「AnimatorController」を作成します。
data:image/s3,"s3://crabby-images/89365/8936523a7c661c557c31a3b01c9712c1766b71de" alt=""
Controllerにくっつけておきます。
data:image/s3,"s3://crabby-images/395c1/395c14057ef042160e24c5887501015f65e64225" alt=""
アニメーションクリップの作成
アニメーションウィンドウを開いて、アニメーションクリップを作成します。「Create」を選択。
data:image/s3,"s3://crabby-images/dad5d/dad5dd61f0e3765a213aba5f2e98555d7b50c422" alt=""
停止状態のアニメーションクリップ
上下左右、それぞれの停止状態のクリップを作成するので、「idle_back」、「idle_front」、「idle_right」、「idle_left」の4つを「CreateNewClip…」から作成します。
data:image/s3,"s3://crabby-images/31857/31857c59dda29824e19a4bb18ccf231ae5249d3a" alt=""
対応する画像をそれぞれドラッグアンドドロップします。下記は後ろ向きの場合。
data:image/s3,"s3://crabby-images/a1d6e/a1d6e3f954bb87a48b2c6c3638804228b502ad52" alt=""
左向きの画像はないので、「idle_left」は右向きの画像を反転させます。「AddProperty」から「FilpX」を追加してチェックします。
data:image/s3,"s3://crabby-images/1cf08/1cf08074132c1695a3ddb644c217ab218ac6b2bf" alt=""
data:image/s3,"s3://crabby-images/34c26/34c26048f0890cf156f2f2a7d2b02b70d744430d" alt=""
歩くアニメーションクリップの作成
同じようにwalkのクリップも4つ作成します。
data:image/s3,"s3://crabby-images/78866/788663aa46a67aff8485e2cede4c7a41dc9451ae" alt=""
対応する画像をすべて選択してドラッグアンドドロップします。
data:image/s3,"s3://crabby-images/35ab7/35ab7afac418da3f8d2b0658db17b5e88aeedc5e" alt=""
下記記事では「左右の移動」に絞ってアニメーションの作成を実装しているので、参考になるかと思います。
待機状態のブレンドツリーの作成
Animatorを開くと、下記のように8つのアニメーションクリップがあります。
data:image/s3,"s3://crabby-images/fd79d/fd79dee369a385ec11db98f347dfbd7ab2684ef0" alt=""
8つ全てを削除し、右クリックして「FromNewBlendTree」を選択します。
data:image/s3,"s3://crabby-images/bb4a8/bb4a896a188433c95214cc70df98f2f81bcbcf6f" alt=""
追加したブレンドツリーの名前をidleTreeに変更。Parametersにfloat型でXとY、bool型でisWalkingを追加します。
data:image/s3,"s3://crabby-images/38972/38972aa924a5913624ffe71eec6d2bee9bc05ca2" alt=""
idleTreeをダブルクリックして、ブレンドタイプを「2DsimpleDirectional」に変更。ParametersをXとYに、モーションを追加して4つにします。
data:image/s3,"s3://crabby-images/6ed02/6ed02aa850b61459ba6d343b000588675b9e2e7a" alt=""
各モーションにアニメーションクリップを割り当てます。Xが横方向、Yが縦方向です。
data:image/s3,"s3://crabby-images/f6bd6/f6bd663732e251ada896ce238a9b071849547f02" alt=""
停止スクリプトの作成
下記スクリプトを作成してPlayerにアタッチします。
using UnityEngine; public class PlayerMove : MonoBehaviour { private Animator anim; private Vector2 movement; private float speed = 5.0f; private void Awake() { anim = GetComponent<Animator>(); } private void Update() { movement.x = Input.GetAxisRaw("Horizontal"); movement.y = Input.GetAxisRaw("Vertical"); if (movement != Vector2.zero) { anim.SetFloat("X", movement.x); anim.SetFloat("Y", movement.y); } } }
キー入力でmovement変数に値を代入し、movement変数をアニメーターのパラメータにそのままセットしているという感じですね。
試しに実行してみて、上下左右キーを押してみます。現時点では待機状態しか設定していないので、下記のようにキャラクターの向きが変わればOK。
data:image/s3,"s3://crabby-images/fbc59/fbc59c9f207b490b0a57e9c7a7ff52cedbe22132" alt=""
歩くアニメーションの実装
ブレンドツリーをコピーしてwalkも同じように作成します。
data:image/s3,"s3://crabby-images/d967b/d967b1a3f48bf48525a2fd5fae672fbc12f210f5" alt=""
idle Treeで右クリックして「MakeTransition」を選択。
停止状態から歩く状態への移動はisWalkingがtrueの時とします。また、Settingsを下記のように変更しておきます。反対方向(歩く状態から停止状態)はisWalkingがfalseの時でセットしておきます。
data:image/s3,"s3://crabby-images/c7bb0/c7bb08ac528cf25fc1de211bdfac90171dbfb781" alt=""
移動スクリプトの作成
最後にスクリプトを作成してPlayerオブジェクトに突っつければ完成です。スクリプト名はPlayerMovingにして中身は下記の様に変更。
using UnityEngine; public class PlayerMove : MonoBehaviour { private Rigidbody2D _rb; private Animator anim; private Vector2 movement; private float speed = 5.0f; private void Awake() { _rb = GetComponent<Rigidbody2D>(); anim = GetComponent<Animator>(); } private void Update() { movement.x = Input.GetAxisRaw("Horizontal"); movement.y = Input.GetAxisRaw("Vertical"); anim.SetBool("isWalking", movement != Vector2.zero); if (movement != Vector2.zero) { anim.SetFloat("X", movement.x); anim.SetFloat("Y", movement.y); } } private void FixedUpdate() { _rb.MovePosition(_rb.position + movement.normalized * speed * Time.fixedDeltaTime); } }
スクリプト変更後、PlayerにAddComponentからRigidBody2DをアタッチしGravityを0にします。
実行してキー入力でキャラクターが動けばOK