LoginSignup
0
1

More than 3 years have passed since last update.

FinalIK for VRChat [アイテム持ち替え]

Last updated at Posted at 2021-02-27

はじめに

VRChat(以下VRC)での使用を想定したFinalIKの設定方法についてまとめました.

今回はFilanIKの基本的な使い方として,

  • LimbIKを使ってアイテムをアバターの手に追従させる
  • 二つのLimbIKを使ってアイテムの追従先を切り替える(手<->頭)

について説明したいと思います.

OverviewCh01.gif

概要

FinalIKとはUnityのアセットで,IKを使ってアバターやオブジェクトの動きを制御できるツールです.
また,VRChat内に持ち込むことができる外部アセットの一つです.

FinalIKを使うと多関節アームを柔軟に操作でき,例として動画のようなアバター改変をすることができます.

対象読者

VRCでFinalIKを使いたい方とします.
また今回はAvatar3.0でアバターをアップロードしたことある方を対象とします.
Avatar3.0についてはVRChat 続・初心者向けUnity備忘録で一通りの設定方法を学ぶことをおすすめします.

環境

注意:
VRCのバージョンによってVRC内でのFinalIKの挙動が変更される可能性があります.

動作確認した環境は以下の通りです.

  • Unity: 2018.4.20f1
  • VRC: 2021.1.2
  • FinalIK
    • $90. セールで安くなるタイミングでの購入がおススメです!

IK(Inverse Kinematics)について

アバター改変時に右腕の動きをチェックしたいとすると,Armatureの肩関節(Shoulder)を回転させて,次に肘関節(Elbow)を回転させて...とするかと思います.

このように各関節を一つずつ動かすことで全体の動きを作っていく仕組みをFK(Forward Kinematics)と呼びます.
肩関節から肘関節の順に回転させることで手の位置を求めるイメージです.

反対に,アバターの手の位置や姿勢が特定の位置・姿勢に合うように,他の関節の回転を計算する仕組みをIK(Inverse Kinematics)と呼びます.
手の位置が先に与えられて,肘関節から肩関節の逆順に必要な回転を求めるイメージです.

VRCでもHMDと2つのコントローラ(+トラッカー)の位置・姿勢からIKを解くことで体全体の動きを制御しているので,VRCをプレイする方には身近な存在だと言えます.

実際にIK制御するために必要なものは,以下の3つになります.

  1. 複数の関節を持つモデル(実際に動かしたいキャラクターや多関節アームなど)

  2. ターゲット(モデルの部位を合わせたい位置・姿勢)

  3. IKコントローラー(VRIK, FBBIK, FABRIK, CCDIKなど)

FinalIKでは様々なIKソルバーがコンポーネントとして用意されています.

全体図

今回はIK制御を用いてオブジェクト(cube)を腕や頭に追従させたいと思います.
overview.png
全体の階層構造は以下の通りです.

  • Avatar(VRC Avatar Descriptorがある階層)
    • Armature(HMDやコントローラで操作するスケルトン)
    • Body(スキニングされたモデル)
    • IKTargets
    • IKControllers
    • IKModel

用意したアバター直下に3つの空オブジェクトを追加して,それぞれ分かりやすいようにIKTargets/IKControllers/IKModelとします.
それぞれのオブジェクトについて実際に説明します.

Point

VRCのバージョン変更によってFilanIKの挙動が変更されることがあります.
またVRCでのIKとFinalIKが衝突し,Unityでは上手く動作していてもVRCに持ち込むとおかしくなるケースを確認しています.
そこで,VRC Avatar Descriptorがある親オブジェクトとArmatureにFilanIK由来のコンポーネントを追加しないことで,VRCとの衝突を防ぎます.

IKModel

IKで動かすためのモデルです.
IKModel.png
IKModelの階層に,2つの関節に相当する空オブジェクト(Bone1, Bone2)と実際に動かしたいオブジェクト(Cube)を親子関係で追加します.
Bone1, Bone2を可視化してみると以下のようになります.
Bone1Bone2Visualization_2.png
このようにBone1, Bone2,CubeのPositionをそれぞれ重ならないように,「く」の字に配置しておきます.
今回はBone2のxを1だけずらし,Cubeは好きな位置に設定しました.

IKTargets

次にターゲットとなるゲームオブジェクトを追加します.
IKTargets.png
IKTargetsの階層に2つの空オブジェクトを用意し,それぞれTarget2Hand, Target2Headとします.右手と頭の位置に対応させます.

ターゲットをアバターに追従させるためには,Armatureのある階層にターゲットを置く必要は必ずしもありません.
下図のようにParentConstraintを用意して,
1. Is Activeにチェックを入れる
2. Constraint Settingsで対応する関節を指定する(今回はhand.RとHead)
すると,アバター直下にあるターゲットが右手や頭に追従するようになります.
IKTargetsInspector.png

IKControllers

今回の主役となるIKコンポーネントを追加します.
IKControllers.png
IKControllersの階層に2つの空オブジェクトを用意し,それぞれController2Hand, Controller2Headとします.

今回はLimb IKを使用します.
Limb IKとは腕や足などの,3つの関節を持つモデルを制御するためのソルバーです.
今回のIKModelは2つの関節+cubeなのでこのコンポーネントが適しています.

下図のようにController2Hand/Controller2HeadにそれぞれLimbIKコンポネントを追加し,

  1. Fix Transformsにチェック
  2. Bone1, Bone2, Bone3にIKModelのBone1, Bone2, Cubeをそれぞれ追加
  3. Targetに対応するTarget2Hand/Target2Headを追加
  4. Position Weightを1に
  5. AvatarIKGoalは今回はLeftFootに

と設定します.

Position Weightを1にするとIKModelのCubeをTargetの位置にぴったり合うように計算されます.
Rotation Weightを1にするとTargetの回転姿勢にも合うように計算されます.

IKControllersInspector.png

これでCubeを追従させる準備がひとまず整ったので,動作確認してみます.
Controller2Handに追加したLimbIKコンポーネントにチェックを入れて,Controller2Headの方はチェックを外しておきます.

プロジェクトを実行後,アバターの肩関節を回転させて,
Cubeが右手に追従していれば成功です.(動画ではTargetを可視化させています.)
finalik_item_hand.gif

IKControllerの入れ替え

Cubeは基本的に右手に追従させて,切り替えで頭に追従させるとします.

今回はそのためにLimbIKを2つ用意しましたが,どちらのコンポーネントもONにしておくと両方についてのIkが解かれて,Cube位置が決定します.

この時Position Weightを1にしているので,必ずどちらかのTargetの方に移動しています.
このままVRCに持ち込むと,どちらのIKが解かれるかが未定なので,挙動が不安定になります.(特に多くのIKコンポーネントを連動させる時に注意)

そこでIKControllersにIK Execution Orderを追加し,

  1. IK Componentsのsizeを1にし,
  2. Element 0 にデフォルトとするController2Handを追加
  3. IK Execution Order自体にチェックをいれる
  4. Controller2Hand内のLimb IKのチェックを外しておく

と設定します.

IK Execution OrderはIKコンポーネントの実行順序を明示するもので,ここに追加されたIKはチェックが外れていても実行されます.

この状態でプロジェクトを実行してみると,デフォルトではController2Handが実行されており,Controller2HeadをON/OFFすることでCubeの位置を入れ替わります.
finalik_item_hand2head.gif
最後にController2HeadのLimbIKをON/OFFするアニメーションを作ればVRC内でも再現できます.
bool変数とON/OFFアニメーションで作れるので非常にシンプルです.

最後に

Unity上では上手く動作しても,VRCの仕様によって挙動がおかしいことがあります.
必ずアバターをアップロードしてVRC内で動作確認しましょう.

0
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1