こんにちは、カバゴトです!今回は、歩くアニメーションのタイミングを制御する方法について超初心者向けに解説していきたいと思います。
今回の記事は前回の続きとなっていますので、もし前回の内容がわからない方は下のほうに記事がありますので、参考にしてください!
![](https://kabaunity.com/wp-content/uploads/2024/03/アニメーションで人を歩かせる方法.jpg)
アニメーションを設定しただけでは、再生ボタンが押され時すぐにアニメーションが発生します。
今回はそのタイミングを制御していきたいと思います!
新しいアニメーションの設定
初期状態
![](https://kabaunity.com/wp-content/uploads/2024/03/image-8-1024x406.png)
![](https://kabaunity.com/wp-content/uploads/2024/03/image-7-1024x402.png)
![](https://kabaunity.com/wp-content/uploads/2024/03/Animation31-1024x615.gif)
初期状態はこのようになっています。
この初期状態がどのようなものかを簡単に下にまとめます。
・「plane」とキャラクターオブジェクトを配置
・Mixamoからダウンロードしたアニメーションをキャラクターにいれる
・アニメーションコントローラーを設定する
この状態から進めていきます!
止まるアニメーションの作成
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-111012-1024x613.png)
再生ボタンの下にある「Animator」をクリックすると、この画面になるので、「Create State」→「Empty」をクリックします。
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-111810-1024x620.png)
次に「右クリック」→「Set as Layer Default State」をクリックします。
これによって、再生ボタンが押されたとき最初に「New State」のアニメーションが適用されるようになります。
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-113830-1024x386.png)
次に「右クリック」→「Make Transition」をクリックすると、矢印みたいなのが出てくるのでそれを交互になるようにつなぎます。
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-121606-1024x632.png)
次にAnimatorの「Parameters」の「+」→「Bool」をクリックします。
私は名前を「boolwalk」にしました。(下の画面ではblRotになっていますが、後boolwalkに変更しています)
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-115316-1024x635.png)
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-115212-1024x634.jpg)
ステイトを2つともクリックし、右側の「Conditions」の「+」クリックします。
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-122745-1024x463.png)
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-23-122834-1024x478.png)
下から上の矢印は「true」、上から下の矢印は「false」にします。
スクリプト作成
![](https://kabaunity.com/wp-content/uploads/2024/03/スクリーンショット-2024-03-26-131445-1024x771.jpg)
「Assets」→「Create」→「C#Script」でスクリプトを作成し、名前を付け、ダブルクリックでvisualstudioを開きます。(私は名前を「human」にしています)
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class human : MonoBehaviour
{
// Start is called before the first frame update
private Animator animation;
void Start()
{
animation = gameObject.GetComponent<Animator>();
}
// Update is called once per frame
void Update()
{
// Enterキーが押されたかどうかをチェックします
if (Input.GetKeyDown(KeyCode.Return))
{
// Animator内の"boolwalk"パラメータをtrueに設定し、歩行アニメーションを再生する
animation.SetBool("boolwalk", true);
}
}
}
このコードで、もしEnterキーが押されたとき、trueつまり先ほどの歩くアニメーションに切り替わることを意味します。これをコピー&ペーストしましょう。
これで完成です!
実際に動かしてみる!
では、実際に動くか確認してみましょう!
![](https://kabaunity.com/wp-content/uploads/2024/03/Animation32-1024x615.gif)
Enterを押すと動きました!
終わりに
最後まで読んでくださりありがとうございます!今回は、歩くアニメーションのタイミングを制御する方法について解説しました。もし、うまくいない場合や意見等あればコメントの方をよろしくお願いします!
この記事が参考になれば幸いです。また、次回のブログでお会いしましょう!
コメント