今回はスプライトアニメーションを作成していく。
Enemyのアニメーション
まずはプレファブフォルダにあるEnemyプレファブをダブルクリックしてプレファブ編集モードで開き、AddComponentからAnimatorコンポーネントを付与する。
data:image/s3,"s3://crabby-images/4850a/4850a2f7e5d2220aad3c58981fb432b415c77779" alt=""
ProjectビューのAnimationフォルダを右クリックしてCreateからAnimatorControllerを作成し名前をEnemyとする。
data:image/s3,"s3://crabby-images/6a154/6a15406ee6aec69e359edce65e9400ecc1a47329" alt=""
Enemyを選択し直して、Enemy アニメーターコントローラを 登録する。
data:image/s3,"s3://crabby-images/6d01c/6d01cb7a8ef044398e0483af5874141c12c02b4e" alt=""
これでEnemyはEnemyアニメーターコントローラで定義されたアニメーションを行うことができるようになった。
Animationクリップの作成
まずはEnemyのAnimationクリップを格納するフォルダを作成しておこう。
AnimationClipsフォルダの中にEnemyフォルダを作成する。
data:image/s3,"s3://crabby-images/1c3b6/1c3b6dcbb028fb9ec589438496d0885dab5a649d" alt=""
LeftWalkアニメーション
それでは、一つずつアニメーションクリップを作成していこう。
Window->Animation->Animation
としてAnimationウィンドウを開く
data:image/s3,"s3://crabby-images/a0217/a0217cdced0886dbe95f40606627566e22ce58f0" alt=""
タブをつかんで作業がやりやすい場所に移動する。下図のように画面下部に持ってくることを推奨。
data:image/s3,"s3://crabby-images/2c2c0/2c2c082255baafe7febce646b19bd800e84c76fc" alt=""
下部にある、Createボタンを押す。
保存ウインドウが開くので先ほど作成したEnemyフォルダに
Enemy@LeftWak.anim
という名で保存する。
data:image/s3,"s3://crabby-images/3eca6/3eca66eb2d9484b395a1ee5c59c1110f84e79957" alt=""
スプライトはあらかじめ用意されてるので
Sprites->Charactersの中にある
WalkSides1~WalkSides4を選択する。
ファイル名を表示したい場合は下部のつまみを一番左にする。
data:image/s3,"s3://crabby-images/ef26c/ef26c2e127fe058293a81dea57169dc802cc21ca" alt=""
4つを選択して、タイムラインにドラッグする
data:image/s3,"s3://crabby-images/f5a40/f5a40313eb59a0a293f6a261811e8954a8e43051" alt=""
下の再生ボタンを押して動きを確認しよう。
いろいろおかしい。。。
まず動きが速すぎる。これは1秒間を60個に分割した上で最初の4コマに配置しているからだ 。サンプル数を4に変更しよう。
data:image/s3,"s3://crabby-images/6d3a5/6d3a53e33117fa4706b638f35b9241d97c2241dc" alt=""
(注意)もし、Samplesの項目が非表示になっていた場合は右の3点ポッチからShowSampleRateにチェックをいれる
data:image/s3,"s3://crabby-images/2b39f/2b39fecc44ea3a9d2ed04bb3920ec50a4d4635ac" alt=""
これで1秒間で4コマになった。再生してみると適切な速さであることがわかる。
次に再生と同時にキャラが上にせり上がる現象だ。これはピボットの設定が異なっていることに起因する。
今回用意されているアニメーションスプライトを見てみるとピボットがBottomCenterに設定されている。
data:image/s3,"s3://crabby-images/8e0f8/8e0f870ab48006873cfe92dbcbf762291fb04ff7" alt=""
なので最初に持ってきたダウンロードしたEnemy画像のピボットをBottomにしてApplyする。
data:image/s3,"s3://crabby-images/1a7ce/1a7ce3b5e19c64dd9dfd1fb765f453bdd2aa1907" alt=""
改めてEnemyプレファブを開き直すと、コライダがずれているのでEditColliderを押して、下図のよういキャラに合わせる。
data:image/s3,"s3://crabby-images/22410/2241018298309aa9773cfd5e253a9ae3ccbc2aff" alt=""
改めて下部の再生ボタンを押してみよう。適切にアニメーションするようになった!
RightWalkアニメーション
次にRightWalkだが、スプライトとしては付属していない。
実はUnityには左右や上下反転のアニメーションクリップを作る方法がある。それで作成しよう。
下図の三角ボタンをクリックして、CreateNewClipを選択する。
data:image/s3,"s3://crabby-images/1baaa/1baaaa76b758df82380b9296dcf2d90ecb484ad0" alt=""
保存画面が開くので先ほど同じEnemyフォルダに
Enemy@RightWalk.anim
として保存する
data:image/s3,"s3://crabby-images/701dd/701dd58e1aefaf3e86b493f6992e849be07041d4" alt=""
まずは先程と同じ左に歩く4枚のクリップを配置し、Samplesを4にする。
data:image/s3,"s3://crabby-images/f5609/f56095c62ddbdee58e004f80b228978498592c24" alt=""
AddProperty -> SpriteRenderer -> Sprite Renderer.Flip Xを選択し+を押す
data:image/s3,"s3://crabby-images/05f08/05f08ce7223046163c58eef67f3bac0831dfd7b1" alt=""
FlipXのチェックボックスをいれる。
data:image/s3,"s3://crabby-images/17dc4/17dc4928bb564bc10b7a57ad6c9d149671f42869" alt=""
再生ボタンを押してみよう。右に歩くアニメーションが再生されるはずだ。
Up & Down
同じ要領で
Enemy@Up.animと
Enemy@Down.animを作成する。
Enemy@Upは
data:image/s3,"s3://crabby-images/6e900/6e90015967ab7db4b7ee3d5356575d2fdaafa6da" alt=""
Enemy@Downは
data:image/s3,"s3://crabby-images/f4fcd/f4fcd070adad2bd1c8e70141dd97753b9b0b57e8" alt=""
から作成する。(ともにsamplesは4)
Animator Controllerの設定
4つのAnimationクリップができたので、これがどのように遷移するのかを定義していく。
AnimatorコンポーネントのControllerのところのEnemyをダブルクリックする。
data:image/s3,"s3://crabby-images/a8454/a8454526b72c0ca8f85908539fc1bc83f5d6e3c6" alt=""
するとAnimatorコントローラウインドウが開くのでタブをつかんで下に移動する。
data:image/s3,"s3://crabby-images/47a18/47a18cb37cd01912c6aa55adf4b9b60a8e5c4d52" alt=""
作成済みの4つのアニメーションクリップが表示されているが、右クリック->Deleteで4つとも消す
data:image/s3,"s3://crabby-images/c238b/c238b6597e0d6b2aa30c2c3ab2b10fbaa18d7903" alt=""
Blend Tree
今回は横方向の移動量と縦方向の移動量の関係からモーションを決定するので、まずはパラメータとしてMoveXとMoveYをfloatで用意する。(最初からあるBlendは消すかRename)
data:image/s3,"s3://crabby-images/f5834/f5834b77606c1719e59c30a61ab5ff796f9626b5" alt=""
今回この4つのアニメーションの遷移はブレンドツリーを使って行う。
何もないところで右クリックしてCreate State -> From New Blend Treeを選択
data:image/s3,"s3://crabby-images/3cee3/3cee393e6837cda32d446bfca1ebcc3be8c7c7bc" alt=""
新しいBlend Treeができるのでそれをダブルクリック
data:image/s3,"s3://crabby-images/7b500/7b500180cfb741fb5249f3071e0f90bc4ddada36" alt=""
Blend Treeをクリックして選択状態にして
BlendTypeを2D Simple Directional
Parameters MoveX と MoveY
とした上で+を押す。
data:image/s3,"s3://crabby-images/c5f4c/c5f4c142e3a173cde017dec2baa6ba1cca6ab920" alt=""
New Blend Treeを選択
data:image/s3,"s3://crabby-images/f9bcb/f9bcbbd166d9d9cb56b9d1eb6db184749d0310ce" alt=""
もう一度、+からNew Blend Tree
data:image/s3,"s3://crabby-images/6534f/6534fbd2798eba617260bf963786a0560a586b70" alt=""
さらに+を押し、Add Motion Fieldを登録したいモーションの数だけ作成する(今回は4つ)
data:image/s3,"s3://crabby-images/378c4/378c44f4b9906f265a8f67c114f91fc90b3d79e2" alt=""
計4つのMotionフィールドを作成したらまるポチを押して作成したEnemy@~のアニメーションを順番に登録し、PosXとPosYの値を以下のように調節する。
data:image/s3,"s3://crabby-images/9ddf6/9ddf687a72b9651e77e4a363ce0456adc2086b62" alt=""
こうすることで、2つの入力された値から適切なアニメーションが再生される。
下部でプレビューできるので上図の赤丸を動かしてみよう。
EnemyControllerの変更
MoveXとMoveYの値によって適切にアニメーションするようになったので
EnemyControllerを以下のように変更しよう。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class EnemyController : MonoBehaviour
{
public float speed = 1.0f;
public bool isVertical;
public float changeTime = 2.0f;
Rigidbody2D rb;
float timer;
int direction = 1;
Animator anim;
void Start()
{
rb=GetComponent<Rigidbody2D>();
timer = changeTime;
anim = GetComponent<Animator>();
}
void Update()
{
timer -= Time.deltaTime;
if(timer < 0){
direction = -direction;
timer = changeTime;
}
Vector2 pos = rb.position;
if(isVertical){
pos.y=pos.y + Time.deltaTime * speed * direction;
anim.SetFloat("MoveX",0);
anim.SetFloat("MoveY",direction);
}else{
pos.x=pos.x + Time.deltaTime * speed * direction;
anim.SetFloat("MoveX",direction);
anim.SetFloat("MoveY",0);
}
rb.MovePosition(pos);
}
void OnCollisionEnter2D(Collision2D other) {
RubyController rubyCon = other.gameObject.GetComponent<RubyController>();
if(rubyCon != null){
rubyCon.ChangeHealth(-1);
}
}
}
ゲームを実行してみよう。敵キャラが適切にアニメーションされていることがわかる。
Rubyのアニメーション
Rubyのアニメーションを同じように1から作成するのも大変勉強になるが、今回は付属してあるのでそれを使っていこう。
Rubyプレファブをダブルクリックしてプレファブモードで開いて、AddComponentからAnimatorコンポーネントを付与。
Controllerの右のまるポチからRubyを選択する。
data:image/s3,"s3://crabby-images/58fcb/58fcba528b5aea00bbbc8eb162a7643acdaf7b72" alt=""
RubyControllerの変更
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class RubyController : MonoBehaviour
{
public float speed=3.0f;
public int maxHealth=5;
int currentHealth;
public int health{get{return currentHealth;}}
public float timeInvincible=2.0f;
bool isInvincible;
float invincibleTimer;
Rigidbody2D rb;
Animator anim;
Vector2 lookDirection = new Vector2(1f,0);
void Start()
{
rb=GetComponent<Rigidbody2D>();
currentHealth=maxHealth;
anim=GetComponent<Animator>();
}
void Update()
{
float horizontal = Input.GetAxis("Horizontal");
float vertical = Input.GetAxis("Vertical");
Vector2 move = new Vector2(horizontal,vertical);
if(move.sqrMagnitude > 0f){
lookDirection.Set(move.x,move.y);
lookDirection.Normalize();
}
anim.SetFloat("Look X",lookDirection.x);
anim.SetFloat("Look Y",lookDirection.y);
anim.SetFloat("Speed",move.magnitude);
Vector2 position = rb.position;
position.x = position.x + speed * horizontal * Time.deltaTime;
position.y = position.y + speed * vertical * Time.deltaTime;
rb.MovePosition(position);
if(isInvincible){
invincibleTimer -= Time.deltaTime;
if(invincibleTimer < 0){
isInvincible = false;
}
}
}
public void ChangeHealth(int amount){
if(amount < 0){
if(isInvincible) return;
isInvincible = true;
invincibleTimer = timeInvincible;
anim.SetTrigger("Hit");
}
currentHealth = Mathf.Clamp(currentHealth + amount,0,maxHealth);
Debug.Log(currentHealth + "/" + maxHealth);
}
}
これで今回は終了だ。次回はRubyの攻撃手段を作成していく。
コメント