アニメーションを適用する基本的な流れ
3D モデルのインポート
手順1
Assets フォルダ内で右クリックして「Import New Asset…」を選択する等してアニメーションさせたい 3D モデルをインポートする。
data:image/s3,"s3://crabby-images/2b8f3/2b8f382446e9c749987adbd11fa9a94ab5933687" alt=""
手順2
インポートした 3D モデルを選択してインスペクターから「Extract Textures…」や「Extract Materials…」を押し、必要に応じてテクスチャやマテリアルを生成する。
data:image/s3,"s3://crabby-images/68d74/68d74d93dec194cb9e2e3d2d619e1545eabea3a1" alt=""
手順3
インポートした 3D モデルを選択してインスペクターから「Rig > Animation Type」で(人型の場合は)「Humanoid」を選択する。
data:image/s3,"s3://crabby-images/6c3d4/6c3d463ae0f5793946a5e3f20b492d1d8326cf36" alt=""
手順4
右下の「Apply」を押してリグを生成する。
「リグ」とは、3Dキャラクターに動きを付ける際の仕組みやコントローラーのことを指します。
3Dアニメーションのリグについて
data:image/s3,"s3://crabby-images/3245d/3245d71ca67255967f8313438043f79d02a11be0" alt=""
Animation Clip のインポートと適用
手順5
FBX 等の形式のアニメーションをインポートし、Assets フォルダ内でモデルのトグルを開いて Animation Clip ファイルを選択している状態で複製(Ctrl + D)する等して Animation Clip ファイルのみを抽出する。
data:image/s3,"s3://crabby-images/10f86/10f86143f9fcdfa38309a93f8cccd220f03ce59b" alt=""
手順6
Assets フォルダ内で右クリックして「Create > Animator Controller」で Animator Controller を作成する。
data:image/s3,"s3://crabby-images/83763/8376393d38a731e308c991d5b6cff42c8414599c" alt=""
手順7
作成した Animator Controller をダブルクリックしてグラフを開く。
data:image/s3,"s3://crabby-images/e08f4/e08f4bb373de8fa98590c8ae34dfa0f6ff0067d1" alt=""
手順8
グラフ内の何も無い場所で右クリックして「Create State > Empty」で空のステートを作成する。
data:image/s3,"s3://crabby-images/29da4/29da486aeb63e97c21a7b7f4c1ad474419942ab8" alt=""
手順9
作成したステートを選択し、ステート名を「Idle」等に変更して Motion に待機モーション等の Animation Clip をアサインする。
data:image/s3,"s3://crabby-images/c7d19/c7d19fc4417b03788cef48903707a487705a2c04" alt=""
手順10
同様にして歩行モーション等のステートをグラフ内に作成し、初期モーション(オレンジ色のステート)上で右クリックして「Make Transition」を選択する。
data:image/s3,"s3://crabby-images/b6302/b63020b6cf35f03cb1ee18e4c7d9f404886f2bda" alt=""
手順11
作成した Transition を歩行モーション等のグレーのステートに接続し、同様にグレーのステートからオレンジ色のステートにも Transition を作成して接続する。
data:image/s3,"s3://crabby-images/242dd/242dd1402586f793d1e79b960b67eb190971b628" alt=""
手順12
左上の「Paremeters」を選択して「+▼」からパラメーターの型を選択して適切なパラメーター名を設定する。
(今回は Bool 型の「Run」パラメーター)
data:image/s3,"s3://crabby-images/03ca8/03ca874d4696b1163c807f437c6938d185837b19" alt=""
手順13
オレンジ色のステートとグレーのステート間の2本の Transition を1本ずつ選択してインスペクターの「Conditions」の右下の「+」を押し、先ほど作成したパラメーターを追加して、この Transition が有効となる時のパラメーターの状態を設定する。
(下の画像の例では Bool 型の Run パラメーターの値が true の時に待機モーションから走行モーションに遷移する)
data:image/s3,"s3://crabby-images/667dd/667dd4195b603415d9433c7fe7e874f6f2594b36" alt=""
アニメーション遷移の制御
手順14
冒頭でインポートした 3D モデルをシーン上に配置し、インスペクターからそのゲームオブジェクトに Animator コンポーネントをアタッチする。
data:image/s3,"s3://crabby-images/cf994/cf994adfa8b0dec1d79ca77652672475b0000ad9" alt=""
手順15
Animator コンポーネントの「Controller」には Animator Controller を、「Avatar」には 3D モデルの Avatar をアサインする。
data:image/s3,"s3://crabby-images/cd991/cd9914098455e1a468a820b96d48d386c47a4b1d" alt=""
手順16
MonoBehaviour クラスを継承したクラスを作成して Animator のパラメーターの値を制御する処理を記述して 3D モデルのゲームオブジェクトにアタッチする。
(以下のコードの例ではスペースキーが押される度に「Run」パラメーターの値を切り替えている)
using UnityEngine;
public class Sample : MonoBehaviour
{
private Animator animator;
private void Start()
{
animator = GetComponent<Animator>();
}
private void Update()
{
if (Input.GetKeyDown(KeyCode.Space))
{
animator.SetBool("Run", !animator.GetBool("Run"));
}
}
}
手順17
ゲームを実行して動作を確認する。
(下の例ではスペースキーを押す度に待機モーションと走行モーションが切り替わる)