カスタムアニメーションを適用する方法
外部アニメーションファイルをインポートし、それをZEPETOキャラクターに適用する方法を学びましょう。
アニメーションをダウンロードしたいサイトにアクセスします。 このガイドはMixamoサイトの使用例です。
📘 Mixamo
希望のヒューマノイドアニメーションをクリックします。
data:image/s3,"s3://crabby-images/00564/00564a9a6759807219cc5635eb53ebbdf5627436" alt="Document image Document image"
アニメーションをダウンロードし、「FBX for Unity (.fbx)」オプションを選択します。
data:image/s3,"s3://crabby-images/66ff2/66ff2b1fba45ee4b6315ea7b26a1c2c2b16cfa04" alt="Document image Document image"
ダウンロードしたファイルをUnityプロジェクトパネルにドラッグアンドドロップします。
data:image/s3,"s3://crabby-images/9a547/9a54762ccf8f5bdebbe85bc555457adf206c7ea9" alt="Document image Document image"
リグタブをクリックし、アニメーションタイプをヒューマノイドに変更します。
data:image/s3,"s3://crabby-images/2e4f7/2e4f7848da1b8cec738bb53b7d9b46fd77bdd73b" alt="Document image Document image"
❗️ 注意
ヒューマノイド設定がないと、ZEPETOキャラクターと互換性がありません。 設定を確認してください。
アニメーション > モーション > ルートモーションノードオプションを<Root Transform>に変更して、キャラクターのアニメーションをよりスムーズでリアルにします。
data:image/s3,"s3://crabby-images/ecb32/ecb320a2c731de3c3d6091f970c17d5c504f55ac" alt="Document image Document image"
📘 Unity ルートモーションノードの選択
ZepetoPlayersコンポーネントインスペクター内のアニメーター変数に関連付けられたアニメーターオブジェクトをクローンします。
- ファイルパス : Packages/zepeto.character.controller/Runtime/_Resources/AnimatorController/ZepetoAnimatorV2.controller
- アニメーターをアセットフォルダーにドラッグします。
コピー後、ZepetoAnimatorV2_Customに名前を変更します。
階層 > ZEPETO > ZepetoPlayersをクリックして作成し、ZepetoPlayersコンポーネントのAnimation Controllerフィールドに作成したアニメーターのコピーをドラッグします。
data:image/s3,"s3://crabby-images/ca5cb/ca5cba06863ee6e17c21b5baba6774395e472ba4" alt="Document image Document image"
ZepetoAnimatorV2_Customをダブルクリックしてアニメータータブを開きます。
新しいアニメーションをアニメーターにドラッグ&ドロップしてアニメーションステートを作成します。
作成したアニメーションステートを右クリックし、次に「遷移を作成」をクリックしてIdleステートに戻る遷移を作成します。
data:image/s3,"s3://crabby-images/73ddc/73ddc9d14576e543234fb17144d4abb7d8fa4e59" alt="Document image Document image"
ボタンをクリックしたときにアニメーションを再生する例を作成しましょう。
data:image/s3,"s3://crabby-images/4da30/4da307016ad7560e178a8d897abededaafe50b35" alt="Document image Document image"
階層 > UI > ボタンを追加します。
- 階層を作成 > 空のオブジェクトを作成し、CharacterControllerに名前を変更します。
- プロジェクトを作成 > 作成 > ZEPETO > TypeScriptを選択し、CharacterControllerに名前を変更します。
- 以下のようにサンプルスクリプトを書きます:
- スクリプトの流れは次のとおりです:
- Start()
- playCustomAnimationButtonにリスナーを追加し、クリック時にアニメーションを再生します。
- ZepetoPlayers.instance.CreatePlayerWithUserId()関数を呼び出してローカルプレイヤーを作成します。
- ローカルプレイヤーのアニメーターコンポーネントを取得し、localPlayerAnimator変数に格納します。
- カスタムアニメーションクリップに設定されたアニメーションクリップを割り当てます。
ボタンをドラッグして、カスタムアニメーションボタンに割り当てます。
6. アニメーションを再生するためにボタンをクリックします。
👍 ZEPETOキャラクター以外のカスタムキャラクターを使用する場合、
ヒューマノイドキャラクターであれば、ZEPETOアニメーションを適用できます。