3Dモデルが向こうから走ってきて一定の座標に来たら止まる、という動きをスクリプトを使い2つのアニメーションを切り替えることで制御してみます。
実行イメージ
シーンの準備
シーンの新規作成します。シーン名はscenePose1としました。
data:image/s3,"s3://crabby-images/bfbc0/bfbc0465142ddada1e940252402bc18bb7fef2eb" alt=""
シーンにPlaneと3Dモデルを配置します。
シーンの軸はY軸に対してX軸を左にとっておきます。
3Dモデルは、名称をPlayerとしました。(3Dモデルはアセットストアで提供されているものでOKです)
data:image/s3,"s3://crabby-images/28260/282602ace3df217883e8896974e98d2fcbb03abf" alt=""
座標はPlane、Player(3Dモデル)ともにPosition X, Y, Z = 0, 0, 0とします。
data:image/s3,"s3://crabby-images/de601/de60100af33916710f4a3ed90d69a57c5787bc97" alt=""
デフォルトのPlane上でキャラを移動させるには少し小さいため、PlaneのScaleは、XとZをそれぞれ10にします。(10倍の大きさ)
data:image/s3,"s3://crabby-images/4fa0b/4fa0bfd2723edbfd442e7f98a72f067a7c04f067" alt=""
空とPlaneのマテリアルは適当に設定してあります。
今回動画で使っている3DモデルはVroid Studioで作ったオリジナルなキャラをUnityに取り込んだモデルです。
取り込み方法は、以下を参照してください。
使っている空のアセットはFantasy Skybox FREEです。
Planeのマテリアル素材はNature Materials vol.1を利用しました。ただこの素材をPlaneにドラッグ&ドロップして設定した状態では画像が荒いため、TilingのXとYを両方とも100にして細かくしています。
data:image/s3,"s3://crabby-images/8cc19/8cc197207854213555abbf8b6ef8a77b6724e757" alt=""
アニメーションの設定
今回3Dモデルのアニメーション素材は、Unity-Chan! Modelアセットを使います。
事前にプロジェクトにインポートしておいて下さい。
Animator Controllerを作成します。名前はRunAndStopとしておきます。
data:image/s3,"s3://crabby-images/141fc/141fc3e708a426020398cba63ca7d1dc950a1c5c" alt=""
RunAndStopをダブルクリックして
走る → 止まる
という遷移を以下のように作成します。
data:image/s3,"s3://crabby-images/92d06/92d06cd7063a2d69981f132b95bf81db635fde91" alt=""
Animator Controllerの作成方法が分からない方は、以下を参考にしてください。
遷移はできましたが、遷移ごとの動きの設定(モーション設定)がまだ出来ていません。
次にRunとStopのモーション設定をしていきます。
Animator ControllerのRunを選択し、インスペクタウインドウに表示されたMotion項目の◎をクリックします。
data:image/s3,"s3://crabby-images/78ad0/78ad06207d7c8d712fb48e00acaf96c08d3049b9" alt=""
表示された中からRUN00_Fを選択します。
data:image/s3,"s3://crabby-images/10626/10626b4aeac81adb6feb00c5a409bddc1dd37fec" alt=""
同じようにしてSTOPの方もMotion項目にWAIT00を設定します。
data:image/s3,"s3://crabby-images/c240c/c240c57c9add31d620155c25fe0cc0a46b36de66" alt=""
ここまでの状態では、RUN→STOPと一連の流れとなり、勝手に遷移してしまうためRUN→STOPへの遷移条件を設定します。(重要!)
遷移条件の設定
AnimatorウインドウのParametersタブを選択し、+をクリックします。
data:image/s3,"s3://crabby-images/8037e/8037e1a978f8d9db60e3e8bfcee5b3b86113eeac" alt=""
Boolを選択します。
data:image/s3,"s3://crabby-images/0cc51/0cc51f79d74b59e310d754330a10008cd760c2b6" alt=""
Boolは真偽値を判定するのに便利です。
true(真)とfalse(偽)の2つの値を持ちます。
名称をstopと入力します。
data:image/s3,"s3://crabby-images/b11c3/b11c33f8d173b9033212b73e77cd5d0ce44b0df1" alt=""
RUN→STOPの遷移部分の矢印を選択します。
インスペクタウインドウに表示された項目の下の方にあるConditions項目の+をクリックします。
data:image/s3,"s3://crabby-images/d7b71/d7b718e7db795717daef8e68057f8024a4485367" alt=""
stop項目がtrueの状態にしておきます。
data:image/s3,"s3://crabby-images/4fcbd/4fcbd094f3b74788473128e454a9b5e0650adf3f" alt=""
遷移条件の設定は以上です。
最後にこの遷移条件を含めた3Dモデルを走らせるスクリプトを作成します。
スクリプトの作成
C#スクリプトを作成します。
名称はRunAndStopとしました。
data:image/s3,"s3://crabby-images/6cacf/6cacf3345b316fc133cf068e5864b64fac1d7c0e" alt=""
スクリプト全体を示します。
RunAndStop
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
public class RunAndStop : MonoBehaviour
{
public float speed; // 移動速度
private Animator animator; // アニメーターコンポーネント取得用
// Start is called before the first frame update
void Start()
{
// アニメーターコンポーネント取得
animator = GetComponent<Animator>();
}
// Update is called once per frame
void Update()
{
// キャラの進行方向に移動する
transform.position += speed * Time.deltaTime * transform.forward;
// Z座標が20を越えたら停止
if(transform.position.z > 20.0f){
speed = 0;
animator.SetBool("stop", true); // アニメーション切り替え
}
}
}
スクリプト作成後、Playerにアタッチします。
data:image/s3,"s3://crabby-images/ed6b9/ed6b967c25b8daef63d480efbdd13e71e208bc11" alt=""
走る速度はインスペクタウインドウのSpeed項目で設定してください。
サンプル動画では、4にしました。
data:image/s3,"s3://crabby-images/28bc8/28bc81a0cc1444b1cabb04f804dafcad1018adff" alt=""
実行確認の前にプレイヤーをカメラから見て遠目にしておきます。
data:image/s3,"s3://crabby-images/2dd3a/2dd3ae98ced1006ef3169e42ba542e529edf74d7" alt=""
カメラ位置については、PlayerのTransform PositionのZ座標を20にして画面一杯にPlayerが収まるくらいが適当です。
ここまでの実行イメージです。
data:image/s3,"s3://crabby-images/65d9f/65d9fcd2cc6655cfa217fe93dd277a73a8742759" alt=""
ちょっとした違和感に気づきますか?
キャラが走ってきて止まったとき、まだ少し走っているアニメ状態にあるのです。(味方によっては足踏みしているようにも見えます)
これは2つのアニメーションの切り替えに掛かる時間が関係しています。
AnimatorタブからRun→Stop項目の矢印を選択し、状態遷移に掛かる時間であるHas Exit Timeのチェックを外してみてください。
data:image/s3,"s3://crabby-images/fc95c/fc95ce7648d7d910f053512d5b6e51d18a67ba30" alt=""
これで自然な形でアニメが切り替わるはずです。
最終イメージ
このスクリプトのポイントは、Updateメソッド内のif文です。
/ Z座標が20を越えたら停止 if(transform.position.z > 20.0f){ speed = 0; animator.SetBool("stop", true); // アニメーション切り替え }
speed=0; で3Dモデルの移動を停止させる同時に、遷移条件で設定したパラメタstop項目をtrueとしアニメーションをStopに遷移させています。
animator.SetBool("stop", true); // アニメーション切り替え
条件によるアニメーション遷移方法は、今回紹介した真偽値を持つBoolが一番分かりやすいかと思います。(Bool以外にも数値条件などによるFloatやIntなどもあります)
以上、Unity:スクリプトを使って条件によりアニメーションを切り替えるでした。
コメント