data:image/s3,"s3://crabby-images/6cdf3/6cdf38ff767028f085d21e76ebbfc8721024bf8a" alt=""
複数のアニメーションをつなげて再生するにはどうしたら良いですか?
data:image/s3,"s3://crabby-images/8ea84/8ea846f3d0c9e54e6f2e6b4acd699bdc4d63061b" alt=""
Input Systemを使うと直感的にできるよ!
Input Systemは、ゲームパッド・キーボード・マウス・センサー等の各種入力デバイスからの入力を汎用的・統合的に取り扱うために導入されたUnityの新しい入力システムです。
Unity for Pro
今回は、キーボード操作で複数のアニメーションを連続再生する方法について解説していきます。
▼完成イメージ▼
では、早速始めていきましょう!
プロジェクトは前回の続きから始めていきますので、手順に不安のある方は以下の記事内容を実施してから、戻ってきてください。
ここでは、キャラクターとアニメーションは、mixamoを使用します。
アニメーションのダウンロード
mixamoからお好きなアニメーションをダウンロードします。ここでは、「歩く」→「走る」→「ブレイクダンス」という流れにするために、「歩く」と「走る」を備えたアニメーションをダウンロードします。(ブレイクダンスは前回の記事でダウンロード済み)
mixamoを開き、[Animations]>[Walk(任意)]>[DOWNLOAD]をクリックします。
data:image/s3,"s3://crabby-images/33995/3399516b6cbfa0991acb9ee130b9ebe9839a6424" alt=""
必要事項を入力し、[DOWNLOAD]をクリックします。
data:image/s3,"s3://crabby-images/dfc62/dfc623e0f66d89ac55ac86ec80741f0af00520b2" alt=""
もう一つ、同様の手順でアニメーションをダウンロードします。
data:image/s3,"s3://crabby-images/61e2e/61e2eee27e51483cbdc0403c3eb50c59cdeedea7" alt=""
アニメーションの設定
Unityにダウンロードしたアニメーションを取り込みます。
[Assets]>[Import New Asset…]をクリックして、先ほどダウンロードをした「〜.fbx」ファイルを選択します。
data:image/s3,"s3://crabby-images/3f706/3f706bc5111d9e8bd85112c98b548b23ce73e607" alt=""
インポートが完了したら、アニメーションの設定をします。
Projectウインドウのアニメーションを選択し、Inspectorウインドウの[Rig]>[Animation Type]から、プルダウンメニューで[Humanoid]を選択して、[Apply]で確定します。
同様の操作を全てのアニメーションで実施します。(解説では3つ)
data:image/s3,"s3://crabby-images/a6b8a/a6b8a4d8767355c2c85cc2c70a760c912a3b510a" alt=""
次に、アニメーションの設定をしていきます。Projectウインドウのアニメーションを選択し、Inspectorウインドウの[Animation]>[Loop Time]にチェックを入れて、[Apply]で確定します。
同様の操作を全てのアニメーションで実施します。(解説では3つ)
data:image/s3,"s3://crabby-images/d50ac/d50acfc25b806553ee30fc755be6906dfc4a8052" alt=""
Input Systemのインストール
[Window]>[Package Manager]をクリックします。
data:image/s3,"s3://crabby-images/bb526/bb5260030a04cd9ffea4ceb9000787a99467e15b" alt=""
[Package Manager]が開きますので、[Packages:Unity Registry]を選択して、検索窓で”inout”と入力します。[Input System]が表示されたら、選択して、[Install]をクリックします。
data:image/s3,"s3://crabby-images/b3d56/b3d569d93b84ac59187fc8cc18ca1dcf79cbaafb" alt=""
Warningが表示されますので、内容を確認して、[Yes]をクリックします。
data:image/s3,"s3://crabby-images/980a3/980a330bb07847a98e2fb9f5fe91dbaab0cdc130" alt=""
変更を保存する場合は、[Save]をクリックします。
data:image/s3,"s3://crabby-images/3c471/3c47121dfe76c6e2308de852ec5df8e9d4a5b73d" alt=""
Player Inputの設定
Hierarchyウインドウのキャラクター[Worker]を選択し、Inspectorウインドウの[Add Component]>[Player Input]をクリックします。
data:image/s3,"s3://crabby-images/c44a7/c44a7a4b797ea1f8e4d744ee000f2e6df0cfa889" alt=""
Hierarchyウインドウのキャラクター[Worker]を選択し、Inspectorウインドウの[Player Input]>[Create Actions…]をクリックします。
data:image/s3,"s3://crabby-images/47169/4716919988388282e41921bc658a5e57a6010ef4" alt=""
[Assets]の配下を保存先に指定して、名前を入力して[Save]をクリックします。ここでは、[WorkerActions]をという名前を指定しました。
data:image/s3,"s3://crabby-images/e2243/e2243bc6855ec95a66812b699b4fed51c0c6009e" alt=""
Projectウインドウに作成したPlayer Input[WorkerActions]が配置されますので、Inspectorウインドウの[Player Input]>[Actions]にドラッグして離します。
キーボード操作でキャラクターを操作するため、Default Scheme:[Keyboard&Mouse]に変更します。Behavior:[Invoke Unity Events]に変更します。
data:image/s3,"s3://crabby-images/69801/698017f2bd244eab3674a75ffd50f67ac253b01f" alt=""
ProjectウインドウのPlayer Input[WorkerActions]をクリックすると、Input Actionウインドウが開きます。
data:image/s3,"s3://crabby-images/aa49b/aa49b364314bf4a7b4d472f897fb4774b1428952" alt=""
[Action]>[Move]>[WASD]を開くと、それぞれの操作と紐づいたキーが表示れされます。
data:image/s3,"s3://crabby-images/f9071/f9071f471699a92c102f3b497bdd34165642b399" alt=""
Hierarchyウインドウのキャラクター[Worker]を選択し、Inspectorウインドウの[Events]>[New script]をクリックします。
data:image/s3,"s3://crabby-images/b1c61/b1c61b2b9ec24df3c2c87e21acb6b9f77df4e7ba" alt=""
任意のファイル名を設定して、[Create and Add]で確定します。
ここでは、WorkerController]としました。
data:image/s3,"s3://crabby-images/0be77/0be77ac69d51afeb9946129f92a13acbe83484d2" alt=""
追加したScriptを開いてコードを書いていきます。
スクリプトの追加
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.InputSystem;
public class WorkerController : MonoBehaviour
{
Vector2 moveDirection;
public float moveSpeed = 5;
public float maxForwardSpeed = 10;
float desiredForwardSpeed;
float forwardSpeed;
const float stageAceel = 5;
const float stageDecel = 10;
Animator anima;
bool IsMoveInput
{
get { return !Mathf.Approximately(moveDirection.sqrMagnitude, 0f); }
}
public void OnMove(InputAction.CallbackContext context)
{
moveDirection = context.ReadValue<Vector2>();
}
private void Move(Vector2 direction)
{
if (direction.sqrMagnitude > 1f)
direction.Normalize();
desiredForwardSpeed = direction.magnitude * maxForwardSpeed;
float acceleration = IsMoveInput ? stageAceel : stageDecel;
forwardSpeed = Mathf.MoveTowards(forwardSpeed, desiredForwardSpeed, acceleration * Time.deltaTime);
anima.SetFloat("ForwardSpeed", forwardSpeed);
}
void Start()
{
anima = this.GetComponent<Animator>();
}
void Update()
{
Move(moveDirection);
}
}
参考に単一アニメーションで動作するスクリプトも載せていきます。(今回は使用しません)
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.InputSystem;
public class WorkerController : MonoBehaviour
{
Vector2 moveDirection;
public float moveSpeed = 5;
public void OnMove(InputAction.CallbackContext context)
{
moveDirection = context.ReadValue<Vector2>();
}
private void Move(Vector2 direction)
{
transform.Translate
(direction.x * moveSpeed * Time.deltaTime, 0,
direction.y * moveSpeed * Time.deltaTime);
}
void Start()
{
}
void Update()
{
Move(moveDirection);
}
}
イベントの追加
Hierarchyウインドウのキャラクター[Worker]を選択し、Inspectorウインドウの[Events]>[Player]>[Move(CallbackContext)]のオブジェクトの枠にドラッグして離します。
そして、[No Function]>[WorkerController]>[OnMove]をクリックします。
data:image/s3,"s3://crabby-images/9b71b/9b71b22a4c10c98676a17148cdfb59265dbff470" alt=""
アニメータの設定
前回の続きからやっている場合、アニメータにアニメーションが追加されていますので、削除しておきます。
data:image/s3,"s3://crabby-images/10615/106157197b5dd988c548b66472e9b14e14805848" alt=""
マウスの左クリックで[Create Sub-State Machine]をクリックします。
data:image/s3,"s3://crabby-images/ced46/ced46a7a9998520f69ec2e9ced73b99a2db85bca" alt=""
Sub-State Machineの名前を任意に設定します。
ここでは、[Movement]とします。
data:image/s3,"s3://crabby-images/1baf8/1baf85260354452952d38f0906f882685cc86396" alt=""
[Movement]が追加されますので、クリックして開きます。
data:image/s3,"s3://crabby-images/f75e1/f75e15782a6b6c2098b8bc9a09af4df94299ecf7" alt=""
マウスの左クリックから[Create State]>[From New Blend Tree]をクリックします。
data:image/s3,"s3://crabby-images/0442b/0442b8e82b34570f708864fde731786101e3f444" alt=""
From New Blend Treeの名前を任意に設定します。
ここでは、[Move]とします。
[Move]が追加されますので、クリックします。
data:image/s3,"s3://crabby-images/ec3d9/ec3d91e0358c5d394b6365e2442666a1c0df1e4a" alt=""
先ほど、Scriptで指定した”ForwardSpeed”に変更します。
data:image/s3,"s3://crabby-images/f2207/f2207f3e1d2d73c2970ad223451442e19db3cbbb" alt=""
Blend Tree上で、左クリックから、[Add Motion]をします。今回3つのアニメーションを繋げるため、3回同じ作業を繰り返します。
data:image/s3,"s3://crabby-images/abcb0/abcb0a8f10beb198c42de9f7f4fd0770bd6033ff" alt=""
Inspectorウインドウにアニメーションが3つ追加されます。
data:image/s3,"s3://crabby-images/56c89/56c89b49dad857fb37a8e29ae51bad78f622dbce" alt=""
「mixamo」では、アニメーション名が「mixamo.com」になっていることがありますので、わかりやすい名前に変更します。Projectウインドウのアニメーションを選択し、Inspectorウインドウの[Edit]を選択します。
data:image/s3,"s3://crabby-images/55df3/55df390e8cc85accb9d11eed230e32732992ea58" alt=""
Inspectorウインドウの[Animation]から、名前を変更して、[Apply]で確定します。
data:image/s3,"s3://crabby-images/d4548/d45482a686b47126ed54cdc239045c1bfe4d5be5" alt=""
data:image/s3,"s3://crabby-images/35696/35696aab8e18efb9fb6c4d9846f6c46c2a32b495" alt=""
[Blend Tree]をクリックして、Inspectorウインドウでプルダウンメニューから[Motion]を選択します。Parameterの時間も短いようであれば適当に大きくしておきます。解説では25にしています。
動作確認
[▶︎]ゲームプレイをクリックします。
キーボードの[W]をクリックすることで、アニメーションが遷移します。
data:image/s3,"s3://crabby-images/f9071/f9071f471699a92c102f3b497bdd34165642b399" alt=""
[歩く]→[走る]→[ブレイクダンス]の3つの動作を連続でつなげることができました。
以上で完成です。お疲れ様でした。