はじめに
今回はDynamicBoneが意図したとおりに動かない時の対処法を解説します。
ボーンが分離する方や1つ上の階層の動きを引き継ぐとお悩みの方はぜひご覧ください。
data:image/s3,"s3://crabby-images/7e8eb/7e8eb758852afce9fbe25c95599e61b2c61d0de6" alt=""
原因
これは枝分かれしたボーンがある事が原因です。
data:image/s3,"s3://crabby-images/c8773/c8773e8ea02fb8455ac353786cb6168cb0cbe509" alt=""
DynamicBoneは仕様上の不具合で枝分かれしたボーンがあるとバグが起こります。
data:image/s3,"s3://crabby-images/699d3/699d377f486e4007a13836b883611421bc478fc2" alt=""
data:image/s3,"s3://crabby-images/e20a6/e20a656dcb8c0e5d070e78916764bb745ec4d336" alt=""
どうして。
対処法
対処法は以下の2つです。
・枝分かれしたボーンを削除
・枝分かれ解除+PositionConstraintで親子付け
この2つについて解説します。
枝枝分かれしたボーンを削除
この方法は簡単です。
しかし、ボーンを失うので動きのディティールが失われます。
Blenderを立ち上げ。
枝分かれしたボーンを選択。
data:image/s3,"s3://crabby-images/6bad1/6bad1d3f079c3e788ca3f9a6e99a13140c3b2fb9" alt=""
Xキー → ボーンで削除。
data:image/s3,"s3://crabby-images/19d9b/19d9baae5f5e87fe9e47303b7427630139484a66" alt=""
辻褄が合うようにウエイトを調整。
data:image/s3,"s3://crabby-images/b964a/b964ab83b0c5cf006f8b16106d79c2ef348f7c06" alt=""
ファイル → エクスポート → FBXで再書き出し。
data:image/s3,"s3://crabby-images/652bd/652bdf7351bf9ab537e3300c684224844450425f" alt=""
こちらのような設定で書き出しました。
data:image/s3,"s3://crabby-images/9cf2d/9cf2d05ee3567fc608d32836d7e291736fda9f23" alt=""
UnityでProjectより編集前の.fbxを選択。
Deleteキーで削除。
data:image/s3,"s3://crabby-images/a9487/a94879b1b4ed28f4136d67bac0c47fcd029a801a" alt=""
編集した.fbxをドラッグ&ドロップで上書き。
data:image/s3,"s3://crabby-images/1263e/1263e9048727ef429f9aa7544016ee83886695d7" alt=""
Hierarchyに上書きした.fbxをドラッグ&ドロップ。
枝分かれの構造が修正されたかを確認。
Dynamic Boneを入れるボーンを選択。
data:image/s3,"s3://crabby-images/25f37/25f37729c839eafc4d83392be4d506498a2d3ad1" alt=""
Dynamic Boneをこのように設定。
data:image/s3,"s3://crabby-images/3e211/3e21105051f17856cc10348a983c1bbe5d5f8000" alt=""
すると分離する不具合が治ります。
data:image/s3,"s3://crabby-images/315d1/315d108b7c0b3d21626493ef59750ffeb3f026e5" alt=""
これで枝分かれしたボーンを削除が完了です。
data:image/s3,"s3://crabby-images/4ce70/4ce70251a47c26049e606b27f374b8f4ecaf7799" alt=""
枝分かれ解除+PositionConstraintで親子付け
Blenderに戻ります。
Tabキーで編集モード。
枝分かれしたボーンを選択。
data:image/s3,"s3://crabby-images/17791/17791672131dd80e494993640b8c2a4066901f96" alt=""
Dynamic Boneを入れる予定のボーンを確認。
Shift+クリックで“1つ前にある階層”のボーンを選択。
data:image/s3,"s3://crabby-images/238ee/238ee38d368ce270924813158a6aca56fd3521d8" alt=""
Ctrl+P → オフセットを保持を選択。
data:image/s3,"s3://crabby-images/72ed5/72ed56f7d74f45b6896c1057f09ac8657a0c5611" alt=""
すると親子関係が変わります。
DynamicBoneを入れる予定の場所に枝分かれ構造が無くなったことを確認。
data:image/s3,"s3://crabby-images/59248/592485b918a728ddd6caf3e048b00848a88a8e9a" alt=""
.fbxで書き出し。
data:image/s3,"s3://crabby-images/46773/467731d360900f52c504422ad6c8628ce2370825" alt=""
UnityでProjectより編集前の.fbxを選択。
Deleteキーで削除。
data:image/s3,"s3://crabby-images/a9487/a94879b1b4ed28f4136d67bac0c47fcd029a801a" alt=""
編集した.fbxをドラッグ&ドロップで上書き。
data:image/s3,"s3://crabby-images/1263e/1263e9048727ef429f9aa7544016ee83886695d7" alt=""
Hierarchyにfbxをドラッグ&ドロップ。
古いデータは_oldなどにリネーム。
data:image/s3,"s3://crabby-images/289ad/289ad2cf5bb6fa3ec623897ce6989bf8b2fec537" alt=""
古い方のDynamic Boneを入れたボーンを選択。
data:image/s3,"s3://crabby-images/36a9b/36a9b06c041d24d8a52909feb35ca8d344cf452e" alt=""
Inspectorを見ます。
Dynamic Bone右上の点3つを選択。
data:image/s3,"s3://crabby-images/11f54/11f54aed97342d9bba5418525a524938d5e0f8bf" alt=""
Copy Componentを選択。
data:image/s3,"s3://crabby-images/8a1e3/8a1e3b132513d2f2de183aa31b95e4997b52b1c9" alt=""
新しく用意したモデルの階層を開きます。
Dynamic Boneを入れたいボーンを選択。
data:image/s3,"s3://crabby-images/2ea7a/2ea7a5b342705469ad75021a8a409b9424d31a29" alt=""
Inspectorを確認。
Transform右上の点3つを選択。
data:image/s3,"s3://crabby-images/212b0/212b02d3217fd3ebcb45dc968069673e6a968fe2" alt=""
Paste Component As Newを選択。
data:image/s3,"s3://crabby-images/0a6bd/0a6bd11d38f7a983b3d1af7312ddc5c2e53399eb" alt=""
Dynamic BoneのRootを確認。
“新しいモデルのボーン”に変更。
data:image/s3,"s3://crabby-images/f9a95/f9a9596b4e050874e461f68204da72da2bc49402" alt=""
枝分かれを解除した方のボーンを選択。
data:image/s3,"s3://crabby-images/1a28f/1a28f503aad57708578ad95127d39be425e4d867" alt=""
Inspector → 3つの点 → Paste Component As Newを選択。
data:image/s3,"s3://crabby-images/7619b/7619b667f4d73c1df79325103e4a9c9967e0639b" alt=""
Rootを確認。
新しいモデルの“枝分かれを解除したボーン”を選択。
data:image/s3,"s3://crabby-images/11092/11092e0743f414fd2dbd9742f45d66b432892523" alt=""
Add Componentを選択。
data:image/s3,"s3://crabby-images/abed7/abed74a8c865354a3b627d32eac60e8d4f787902" alt=""
検索欄にPosと入力。
Position Constraintを選択。
data:image/s3,"s3://crabby-images/cf0e7/cf0e7ac95ac213ef938400d18eb16af61e942ff6" alt=""
Is Activeにチェック。
Sources右下の+をクリック。
data:image/s3,"s3://crabby-images/79214/79214d204c3528aa0d92e9757c4d726fdd037450" alt=""
Sourcesで枝分かれを修正する前の“本来、親だったボーン”を選択。
※新しいモデルの方から選んでください。
data:image/s3,"s3://crabby-images/6dfc2/6dfc25b0e95f099c24260f956e5bf6e9b272c0b2" alt=""
Playボタンを押します。
data:image/s3,"s3://crabby-images/609e0/609e05e223849e30238458430c56ff8d1c6339cc" alt=""
この状態で動かすと疑似的に枝分かれ構造を再現できます。
これでDynamic Bornの修正が完了です。
data:image/s3,"s3://crabby-images/8beca/8becabe197a3db61320d33386887e1a5e97bd7ef" alt=""
VRChat上でも動きます。
data:image/s3,"s3://crabby-images/99a63/99a63a73b86b3b5fc78e2ccc056c7d162be74ea1" alt=""
※補足
コンポーネントについての補足です。
data:image/s3,"s3://crabby-images/82aaf/82aaf9f11041d892f389fad1022d3f051afd83a2" alt=""
親子関係付けならParentConstraintを使うと何故か動きませんでした。
ParentConstraintとDynamicBoneはTransformeのパラメーターを書き換えるコンポーネントです。
なので競合するようです。
data:image/s3,"s3://crabby-images/f79e8/f79e8e057abd982500012ed126783aa7915786c4" alt=""
なのでPositionConstraintを使ってます。
これは位置だけを書き換えるコンポーネントのようです。
なのでDynamicBoneの回転が反映されるみたいです。(たぶん)
data:image/s3,"s3://crabby-images/6574a/6574ad08b468f2fe3547a2f6813de04de9adf704" alt=""
まとめ
今回はDynamicBoneが分離する時の対処法を紹介しました。
【原因】
DynamicBoneは枝分かれした構造のボーンに使うとエラーが起こる。
【対処法】
・枝分かれしたボーンを削除
・枝分かれ解除+PositionConstraintで親子付け
コメント