Open kaikoga opened 1 year ago
主に BlendShapeClip (VRM0) / Vrm10Expression (VRM1) のBlendShapeがIndex参照なのとRendererの指定方法がAvatarRootTransformからのRelativePathなのでいろいろと苦しいことになっています。
あといずれもScriptableObjectがScriptableObjectの参照を持つ形の(AnimationControllerに近い)データ構造なので、(AAOの)AnimatorControllerMapperによるDeepCloneっぽい扱いが必要です。とりあえず仮でAnimatorControllerMapperのDeepCloneに相乗りしてますが、この実装をMAにコピーする必要が起きる前にNDMFあたりにもう少し使いやすいDeepCloneのAPIを生えてると嬉しそうな気持ちがあります。
ちなみにVRM1のFirstPerson(一人称視点からどのRendererが表示されるか指定できる仕組み。言い換えると、VRM標準のMA Visible Head Accessory)はVrm10Objectに(つまり表情と一緒のScriptableObjectに)格納されるので、MAでFirstPersonをマージしたい時はMAでVrm10ObjectをDeepCloneできる必要があります。大変そう。
「AAOはVRMをサポートします」って言えるようになるまでにやらなきゃいけないAAO外の課題
bdunderscore/ndmf#71 (これを入れない限り、VRCSDKとUniVRMが両方入っているプロジェクトではVRCアバターしか扱えない)
bdunderscore/ndmf#72 (↑の とりあえず仮でAnimatorControllerMapperのDeepCloneに相乗りしてます
をどう解消するか)
Discussed in https://github.com/anatawa12/AvatarOptimizer/discussions/522
Support VRM0 / VRM1 avatars in AAO components.
Required Tasks
AAO_VRM1
against "com.vrmc.vrm" and/orAAO_UNIVRM
AAO_VRM0
against "com.vrmc.univrm"Affected VRM0 / VRM1 components list
Broken by AAO
Modified but not broken by AAO
Unaffected by AAO
AAO component list
Breaks Typical VRM Setup (update required)
Possible Invalid Setup (wontfix)
Independent components (nothing to do)
Legacy or Non-VRM components (wontfix)