目次
今回はクリックした位置に向かってキャラクターが左右に移動する機能をAnimatorを使って開発します。
data:image/s3,"s3://crabby-images/22a13/22a1367137bdf5fe8c8c785106293e30b0983a96" alt=""
Animationの作成
まずは、[プロジェクト]ウィンドウの右クリックメニューから「Animation」を作成します。名前は適当にXMoveにしておきます。X位置のアニメーションを下記の画像のように作成します。
data:image/s3,"s3://crabby-images/d7214/d7214355dd5f8f38af5af618f621ec490442e792" alt=""
移動量を一定にするため左下のCurvesボタンからアニメーションカーブを直線にします。線の左右の端を右クリックメニューのAutoで自動設定できます。
data:image/s3,"s3://crabby-images/dffd4/dffd403014e410ca5b069c8eac56a74b555a2f9f" alt=""
Animator Controllerの作成
[プロジェクト]ウィンドウの右クリックメニューから「Animation Controller」にを作成します。名前は適当にPlayerAnimatorにします。先ほど作ったXMoveアニメーションを配置してXMoveステートを作成。
data:image/s3,"s3://crabby-images/2ebf0/2ebf0f9181160e5e9b34aca2f2c9f8e145181acd" alt=""
Animator Controller – Parametersの設定
移動量を指定するパラメータを作成しておきます。
data:image/s3,"s3://crabby-images/44116/44116221f248888a1f115173aa7ae4a093e86b09" alt=""
XMoveステートの Inspector
Multiplierプロパティに先ほど作ったMoveのプロパティを選択します。
data:image/s3,"s3://crabby-images/f797d/f797dc040e9f97d9b1089503a6ed810470aeb656" alt=""
サンプルコード
移動量を調整できるようにmoveRate変数を宣言します。
using UnityEngine;
public class PlayerMove : MonoBehaviour
{
public Animator animator;
[Range(0, 99)]
public int moveRate = 80;
void FixedUpdate()
{
float input = 0;
if (Input.GetMouseButton(0))
{
var worldCamera = Camera.main;
var screenPos = RectTransformUtility.WorldToScreenPoint(worldCamera, transform.position);
input = Input.mousePosition.x - screenPos.x;
}
animator.SetFloat("Move", input / (100 - moveRate));
}
}
完成!
data:image/s3,"s3://crabby-images/36824/3682450314f73cdd236af5af80a755311d0f2c25" alt=""
ダウンロード
下記リンクからソースコード一式をダウンロードできます。
参考文献
[Unity マニュアル ブレンドツリー](https://docs.unity3d.com/ja/2019.4/Manual/class-BlendTree.html)
[Unity マニュアル アニメーション遷移](https://docs.unity3d.com/ja/2018.4/Manual/class-Transition.html)