data:image/s3,"s3://crabby-images/b5bc6/b5bc647366e86a97e729ea72aaba487b3d28a21a" alt=""
キャラクターにジャンプをさせるにはどうすればいいのだろう。
data:image/s3,"s3://crabby-images/8ea84/8ea846f3d0c9e54e6f2e6b4acd699bdc4d63061b" alt=""
そうだね、今まで学んだ内容に少し手を入れるだけなんだ。
ジャンプをマスターすることで、平面移動だけでなく、空中移動や障害物を乗り越えたりと、動きの自由度が格段に上がるので、是非覚えて、使っていこう!
▼完成イメージ▼
プロジェクトは前回の続きから始めていきますので、手順に不安のある方は以下の記事内容を先に実施してから、戻ってきてください。
では、早速始めていきましょう!
ここでは、キャラクターとアニメーションは、mixamoを使用します。
キャラクターの設定
まずは、キャラクターの設定をしていきます。
キャラクター[Worker]を選択し、Inspectorウインドウの[Add Component]>[Capsule Collider]をクリックします。
data:image/s3,"s3://crabby-images/25b20/25b2076fbe601e8ffa121e5769297fe21b16549e" alt=""
続いて、キャラクター[Worker]を選択し、Inspectorウインドウの[Add Component]>[Rigidbody]をクリックします。
data:image/s3,"s3://crabby-images/04f41/04f41ad97cf74ae7ab22204ec94a14bb6ca562ca" alt=""
[Capsule Collider]は、キャラクター[Worker]の背丈に合うようにパラメータを調整し、[Rigidbody]は、[Mass]を人の重さ(kg)程度に設定しておきます。今回はジャンプなので、Rotationに制約をかけておきます。
data:image/s3,"s3://crabby-images/8a22d/8a22d7a4a6deb6b48710a1a0822c72f76ded2f12" alt=""
レイヤーの追加
次にレイヤーを追加します。
キャラクター[Worker]を選択し、Inspectorウインドウの[Layer]のプルダウンメニューをクリックし、[Add Layer…]をクリックします。
data:image/s3,"s3://crabby-images/075d9/075d9668db29a8144b1f12817ed10abdfa7fb257" alt=""
[Layers]の中で、空いている[User Layer○]に、キャラクター名(任意)を入力します。
data:image/s3,"s3://crabby-images/9689a/9689ac391d8c9693c4d7db3b256fbdb38b59ab83" alt=""
前で設定したレイヤー名をInspectorウインドウの[Layer]のプルダウンメニューから選択します。
data:image/s3,"s3://crabby-images/82a64/82a64b922b2c7a04f3d7ecb278ab4dfde0fb4c75" alt=""
レイヤー変更の確認画面が表示された場合は、[Yes]をクリックします。
data:image/s3,"s3://crabby-images/77c3d/77c3d005a654576c9ddccf10de02438367228ee5" alt=""
Input Actionの設定
Input Actionでコマンドを追加していきます。
Projectウインドウのキャラクター[Worker]の配下のInput Action[WorkerActions]をクリックします。
data:image/s3,"s3://crabby-images/0a0dd/0a0dda6d70dca59eef4e0317f2298b62ffd14591" alt=""
Input Actionが開きます。[Actions]の右の[+]をクリックして、アクション[Jump]を追加します。
data:image/s3,"s3://crabby-images/4d8d5/4d8d5c71bfd3366f67df649571462c7df866c620" alt=""
アクション[Jump]にコマンドを割り当てるために、[Path]のプルダウンメニューをクリックして、検索窓で”Space[Keyboard]を探して、クリックして確定します。
data:image/s3,"s3://crabby-images/2ba80/2ba804bcbdbc6a394cc40a7c5aa3d55ecb88841b" alt=""
[Use in control scheme]で、[Keyboard&Mouse]にチェックを入れます。
data:image/s3,"s3://crabby-images/c6bbe/c6bbe757aa39065b8a88dee9db7c53025087da85" alt=""
完了したら、[Save Asset]をクリックしてウインドウを閉じます。
これで、キーボードのスペースキーを押すと、Jumpを呼び出すことができます。
キャラクター[Worker]を選択し、Inspectorウインドウの[Player Input]>[Events]>[Player]>[Jump]から、[+]をクリックして、以下のように設定します。
data:image/s3,"s3://crabby-images/2a305/2a305bdc0868ec80590e4b312a5cd35b6a42a882" alt=""
キャラクターのインストール
キャラクターを選択します。
ここでは、mixamoのアニメーションを使用します。
ログインをして、[Animations]>[jump]>任意のアニメーションを選択して、[Download]をクリックします。
data:image/s3,"s3://crabby-images/3650f/3650f1be5b0493c82badc7da0fa2390ac720b6d7" alt=""
[Format]を[FBX for Unity(.fbx)]に変更し、[DOWNLOAD]をクリックします。
data:image/s3,"s3://crabby-images/66a9e/66a9e333d99eaa7420d40ec2130734767040de93" alt=""
Unityエディタに戻り、メニューの[Assets]>[Import New Asset…]でダウンロードした「〜.fbx」ファイルを選択して、取り込みます。
data:image/s3,"s3://crabby-images/9762f/9762f7aefcef0b9cd5cc19986fcc72abcbcba252" alt=""
Projectウインドウで、インポートしたアニメーション[SideJumping]を選択して、Inspectorウインドウの[Rig]を以下のように変更します。
※[Source]は、キャラクター[Worker]のAvatorを選択します。
data:image/s3,"s3://crabby-images/f777d/f777d41a0aa79d05114dcfee8e805ecc5f83b1d8" alt=""
同様に、Inspectorウインドウの[Animation]も以下のように変更します。
※ここでは、[SideJumping]に変更しましたが、わかりやすい名前であればOKです。
data:image/s3,"s3://crabby-images/ec0d0/ec0d083be64cb8560e1550702b4ca7c5f7c54a7b" alt=""
アニメーションの設定
Animationウインドウを変更していきます。
[Base Layer]を選択し、右クリックで[Create Sub-State Machine]をクリックします。
data:image/s3,"s3://crabby-images/13e65/13e65af91e2a6f146a9abbf17a76b30f13c135d7" alt=""
[Sub-State Machine]名をわかりやすいように変更します。(任意)
data:image/s3,"s3://crabby-images/81c25/81c25a3cf37b4f918b6819d759fe714aca9ad7d1" alt=""
作成できた[Sub-State Machine]をクリックします。
data:image/s3,"s3://crabby-images/28e42/28e4267d24ed3780d542395b97b15f5d1cb6ffad" alt=""
Projectウインドウの任意のアニメーション[Walking]をドラッグして[Animator]に取り込みます。取り込んだアニメータを選択して、右クリックから[Set as Layer Default State]をクリックします。
data:image/s3,"s3://crabby-images/d5517/d55171ba0f4176c961ac35d37d2fbc7d71106a83" alt=""
次に、ジャンプのアニメーション[SideJumping]も同様にドラッグしてAnimatorに取り込みます。
data:image/s3,"s3://crabby-images/ceb63/ceb631f7bef462928b9d9cc3c4d3692f862db308" alt=""
最初に取り込んだアニメーション[Walking.com]を選択して、右クリックから[Make Transition]をクリックして、アニメーション[SideJumping]をクリックします。
[Walking.com]と[SideJumping]が矢印で結ばれます。
data:image/s3,"s3://crabby-images/6c3ba/6c3ba0e4578caefb153aec08960a099ee77c249c" alt=""
ここまでで、動作を確認します。
[▶︎]ゲームプレイをクリックします。
[Walking.com]のアニメーションが終了した後に[SideJumping]のアニメーションが再生されます。
アニメーションを[Walking.com]から[SideJumping]に移行されるために、ブーリアン型の変数を定義します。
[+]>[Bool]をクリックします。
data:image/s3,"s3://crabby-images/60e6e/60e6ede19aeaa169e1b608daf772fd3967732542" alt=""
アニメーション[Walking.com]と[SideJumping]を繋ぐ矢印をクリックして、Inspectorウインドウの[Conditions]から[+]をクリックして、プルダウンメニューから先ほど定義したブーリアン型の変数名を選択します。
data:image/s3,"s3://crabby-images/615fb/615fb363d557ae3b8e7068cc95f1438055284e11" alt=""
スクリプトの追加
Hierarchyウインドウの[Worker]を選択し、Inspectorウインドウで、Script[WorkerController]をクリックします。
data:image/s3,"s3://crabby-images/840c0/840c03a67a69e6e59e7ece0a7c95a48f0b76a7af" alt=""
Scriptを以下のように入力します。
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.InputSystem;
public class WorkerController : MonoBehaviour
{
Vector3 moveDirection;
public float moveSpeed = 2;
public float maxForwardSpeed = 8;
public float turnSpeed = 50;
float desiredSpeed;
float forwardSpeed;
float jumpDirection;
const float groundAccel = 5;
const float groundDecel = 25;
Animator anima;
bool IsMoveInput
{
get { return !Mathf.Approximately(moveDirection.sqrMagnitude, 0f); }
}
public void OnMove(InputAction.CallbackContext context)
{
moveDirection = context.ReadValue<Vector2>();
}
public void OnJump(InputAction.CallbackContext context)
{
jumpDirection = context.ReadValue<float>();
}
void Move(Vector2 direction)
{
float turnAngle = direction.y;
float fDirection = direction.y;
if (direction.sqrMagnitude > 1f)
direction.Normalize();
desiredSpeed = direction.magnitude * maxForwardSpeed * Mathf.Sign(fDirection);
float acceleration = IsMoveInput ? groundAccel : groundDecel;
forwardSpeed = Mathf.MoveTowards(forwardSpeed, desiredSpeed, acceleration * Time.deltaTime);
anima.SetFloat("ForwardSpeed", forwardSpeed);
transform.Rotate(0, turnAngle * turnSpeed * Time.deltaTime, 0);
}
void Jump(float direction)
{
if (direction > 0)
{
anima.SetBool("SideJumping", true);
}
}
void Start()
{
anima = this.GetComponent<Animator>();
}
void Update()
{
Move(moveDirection);
Jump(jumpDirection);
}
}
動作確認
カメラのアングルを調整します。
Hierarchyウインドウの[CM vcam]を選択し、Inspectorウインドウで、任意のアングルに調整します。
data:image/s3,"s3://crabby-images/34ed2/34ed284da5da762126d6c7f7e26a641c6f16a694" alt=""
[▶︎]ゲームプレイで動作を確認します。
スペースキーを押した時に、ジャンプのアニメーションに移行していれば完成です。
※Loop処理しているので、一度ジャンプのアニメーションに移行するとエンドレスでジャンプします。
以上です。お疲れ様でした。