![見出し画像](https://assets.st-note.com/production/uploads/images/99765267/rectangle_large_type_2_c4b709fa26b43e2c5b2a1c2142f3d42d.png?width=1200)
初歩からのフォトグラメトリ~人物のフォトグラメトリを活用して3Dアバターを作る方法(VRM形式)〜【写真からゲームで使える3Dキャラを作ってみよう! vol.10】
■自分似のアバターでメタバースデビュー!?
こんにちは、茶里です。さて、人物のフォトグラメトリにフォーカスしたハウツーをご紹介している「初歩からのフォトグラメトリ」シリーズ。
いままではどちらかというと、人物フォトグラメトリのやり方そのものを紹介することが多かったですが、今回はフォトグラメトリで作成したモデルを使って何かを作ってみよう、という内容になります。
そして、何を作るのかというと…
![](https://assets.st-note.com/img/1678124124608-2ABDz1UuVA.png?width=1200)
こちら!いまをときめく(?)VRプラットフォーム、VRChatのアバターです!
![](https://assets.st-note.com/img/1678124388022-GFNE7V44Kb.png?width=1200)
実はこちらのアバター、写真のモデルさんのフォトグラメトリデータを活用して作成しています(なので、全体的にデフォルメはされているものの、輪郭などはかなり一致しているのが分かるかと思います)
![](https://assets.st-note.com/production/uploads/images/99758660/picture_pc_0964513c70c8a27c818001c0e7f449bf.gif?width=1200)
また、この3DアバターはVRM形式で作成しています。記事では試しにVRChatにアップロードしていますが、それ以外にもいろんなソフトウェアで使えるので、様々なことに応用の効く内容になっているかと思います。
思いの外長々としてしまいましたが、その分、書いてある順番通りにやるだけで、誰でも作れるようにしたつもりです、、、一部分だけでも参考になるところがありましたら幸いです!
では早速、その方法を順を追ってご紹介したいと思います!
■ご協力いただいたモデルさん
![](https://assets.st-note.com/img/1678125668250-o7nYeMFsth.png?width=1200)
今回3Dアバターのモデルになっていただいたのは、俳優、モデルの山川愛理さんです。非常に丁寧なお仕事ぶりに助けられ、とても綺麗な3Dデータを作成することができました!
★Profile★
山川 愛理(やまかわ あいり)
プラチナムプロダクション所属。大型ガールズグループ『Shibu3 project』ブルークラス、2022年 カンコー委員会5期生。
instagram⇒airin_1214_
Twitter⇒airin_1214
■ReadyPlayerMeを活用します
前回の記事でもご紹介した、このReadyPlayerMe(RPM)は、自分の写真1枚から、自分に似たアバターが作成できるというサービス。なんと、ダウンロードしたアバターを加工するのも、非商用なら自由となっています。
あらゆるものをゼロから作るのは大変です。なので、今回はこのアバターをフォトグラメトリのデータを活用して、より本人に似ているように加工する……という方法でアバターを作成したいと思います。
![](https://assets.st-note.com/img/1678255273847-0Yv8mNj1uS.png?width=1200)
右側がフォトグラメトリデータで加工したデータ
■作業の主な流れ
こんな感じで進めていきます。細かなプラグインなどもアレコレ使いますが、インストール方法から使いかたまで、丁寧に解説しておりますので心配ご無用です。
①RealityCaptureでフォトグラメトリデータ作成
②ReadyPlayerMeで加工元となるアバターを作成
③Blender,Zbrush,Wrap3でアバターを加工
④加工したアバターをUnityにとりこむ
⑤UnityからアバターのデータをVRChatにアップロード
■コスト感
上記の過程でいろいろ有料ソフトを使ってるので、みなさんが試したときに、発生するであろう費用についても触れておきます。
RealityCapture
→今回くらいのフォトグラメトリモデルを、都度支払い(PPI方式)で支払うと5ドルくらい。詳しくは第4回記事のココを参照。
ちなみに撮影そのものについては、今回の内容であれば第9回で扱ったiPhoneを使った方法で十分だと思います。
Zbrush
→maxonのサイトを見ると現在、年払いで月額4400円、月払いで月額5500円。14日間の無料体験版もあります。
なお、より安価なzbrush coreもありますが、この記事で使っているGoBプラグインはcoreでは使えません。なお学生さんは9.99ドルで、こちらのmaxon oneのパックが使えます。
Wrap
→インディーライセンスが370ドル(!)しますが、30日間の無料体験版があるのと、なんと学生は無料。詳しくは第8回の記事のココを参照。
ちょっと高いのですが、人物のフォトグラメトリをよくやる人なら、一度は体験していただきたい便利さです。
Blenderや、使用しているその他のプラグインは無料です。では次項から早速作成にとりかかっていきます!
■まずはRealityCaptureでフォトグラメトリ
最初はまずフォトグラメトリデータの作成です。
Reality Captureのインストール方法や使いかたは下記の記事を参照ください。
今回は、下記の記事でご紹介した、複数台のカメラを同期させながら、ターンテーブル撮影する方法で撮影したのですが、
今回はそこまで精度が求められるわけでもありませんし、iPhoneを使った方法でも十分かなと思います。
詳細は割愛しますが、以下製作過程です。
![](https://assets.st-note.com/img/1678256879294-xv0dBQcg5D.png?width=1200)
![](https://assets.st-note.com/img/1678256956390-wnFjln7I4Q.png?width=1200)
![](https://assets.st-note.com/img/1678259508140-nZhfe64bIB.png?width=1200)
![](https://assets.st-note.com/img/1678261039554-wJh9qvaSHu.png?width=1200)
作成したモデルは、OBJ形式で出力して保存しておきます。
■Blender, GoB, Zbrushのセットアップ
こちらは前回の記事を参考にご準備ください。説明は割愛します!
■Unityのインストール
▶①必要なバージョンを確認
VRchat に対応したアバターを作成するには、対応したバージョンのUnityをインストールする必要があります。
下記のサイトにアクセスしてみて
赤丸のところに書いてあるのが、現在対応しているバージョンの番号です。記事執筆の時点ではUnity 2019.4.31f1となっています。
![](https://assets.st-note.com/img/1677853146194-Xljbf6pNm5.png?width=1200)
▶②Unity Hubをインストール
Unityをダウンロードする前に、ここからUnity Hubをダウンロードしてインストールしましょう。
▶③必要なバージョンのUnityをインストール
①で確認したバージョンのエディターをインストールします。「エディターをインストール」をクリックして……
![](https://assets.st-note.com/img/1677853146478-DoVKMhWeDo.png?width=1200)
「アーカイブ」タブから「ダウンロードアーカイブ」へ
![](https://assets.st-note.com/img/1677853146313-EnXCXHPM0v.png?width=1200)
この「Download LTS Releases」をクリック。
![](https://assets.st-note.com/img/1677853146779-RLouGnO6m2.png?width=1200)
プルダウンタブから、探しているバージョンの番号の頭のほうと一致する箇所を探します。今回探しているのは「Unity 2019.4.31f1」なので「2019.4」をクリックします。
![](https://assets.st-note.com/img/1677853147206-dpMHHEzRyD.png?width=1200)
見つけたらこの部分をクリックします
![](https://assets.st-note.com/img/1677853146140-rZnDH1kx5p.png?width=1200)
するとインストール用のプログラムがダウンロードされるのでクリック
![](https://assets.st-note.com/img/1677853145849-Tdd9hdgPzK.png)
![](https://assets.st-note.com/img/1677853148260-zrBRx9kWu0.png?width=1200)
▶④インストールできたのを確認
Unity Hubに戻って「インストール」の項目に、③でインストールしたバージョンが表示されていれば成功です。
※反映されていなかった場合も、PC再起動などすれば反映されると思います
![](https://assets.st-note.com/img/1677853145947-QeqcoCOELT.png?width=1200)
■VRchatの準備
▶①まずはアカウントの登録
今回の最終目標はVRchat用のアバターを作成してアップロードすることなので、下記を参考に登録を進めてください。あと、トラストレベルを「User」まで上げておきます(じゃないとアバターをアップロードできない)
ちなみに、こちらの記事に詳しいですが、トラストレベルをすぐに上げられるよう課金することも可能です!(自分も試してすぐ上がりました)
▶②Creator Comapnionをダウンロード
つづいて、VRchatのユーザーのホーム画面から、Unityでのアバターの作成に便利な「Creator Companion(クリエイターコンパニオン)」をダウンロードします。
こちらのDownload Creator Companionをクリックして
![](https://assets.st-note.com/img/1677853746703-XHjuCJ20yI.png?width=1200)
このexeファイルをダウンロードします
![](https://assets.st-note.com/img/1677853869697-83ohNnHthm.png)
exeを起動して、自分にだけインストール(上)か、全ユーザーにインストール(下)を選びます。
![](https://assets.st-note.com/img/1677853896680-DSjj12E9Bz.png)
規約を承諾して次へ
![](https://assets.st-note.com/img/1677853938961-jScPRoIeSF.png?width=1200)
お好きなインストール先を選びます
![](https://assets.st-note.com/img/1677853993361-iyghVylzr3.png?width=1200)
そのままNextを選んでいけばインストール完了です。
▶③Creator Comapnionでプロジェクト作成
さっそく、アバターを作成するためのUnityプロジェクトを作成してみます。
インストールが成功していれば、スタートメニューにこれが追加されているはずなので、起動します。
![](https://assets.st-note.com/img/1677854105410-SYYStMxy71.png)
「New」⇒「Avatar」の順にクリック。
![](https://assets.st-note.com/img/1677854261946-QpSJjhrBvV.png?width=1200)
適当なプロジェクト名を入力して「Create」をクリックします。
![](https://assets.st-note.com/img/1677854319884-0xYjWE3W8d.png?width=1200)
そしてこの画面からOpen Projectをクリック
![](https://assets.st-note.com/img/1677855115847-0tU3nJIbQH.png?width=1200)
するとUnityが立ち上がり、VRchatのアバター作成用のプロジェクトを作ってくれます。
![](https://assets.st-note.com/img/1677854372621-4OWxM8xkNX.png?width=1200)
VR CHAT SDKが開くので、ここに登録したVRChatのアカウント情報を入力してログインします。
![](https://assets.st-note.com/img/1677854425467-h7ENmhStuy.png?width=1200)
ログインに成功して、トラストレベルが必要なレベルまで上がっていれば「Allowed to publish avatars(アバター作成が認められている)」の表示が出るはずです。
![](https://assets.st-note.com/img/1677854487137-xwVmmHGyaB.png?width=1200)
ログイン完了したら、いったん右上の✖でウィンドウ閉じてもOKです。
▶④アバターを入れるフォルダを作成してメモしておく
この後作成するアバターを入れるフォルダを作っておきます。Assetsで右クリックして、New>Folderの順にフォルダを作成して、適当に名前をつけます。ここでは"Avatar"としました。
![](https://assets.st-note.com/img/1677855352786-5htpVEvvdv.png?width=1200)
作成したフォルダを右クリックして「Shown in Explorer」をクリック
![](https://assets.st-note.com/img/1677855466067-Lf8lzlzEW9.png?width=1200)
エクスプローラでフォルダの場所が表示されるので、この場所のアドレスをコピペしてメモしておきます。
![](https://assets.st-note.com/img/1677855523945-Fec4oGnP89.png?width=1200)
作業が終わったら、Save Projectでプロジェクトを保存しておきます。
![](https://assets.st-note.com/img/1677855633498-vLkdnGMNjo.png?width=1200)
■UniVRMのインストール
▶①GithubからUniVRMをダウンロード
今回、作成したアバターを途中でVRMというフォーマットに変換します。VRMで作ったアバターはいろんなアプリで使うことができ、VRchatもそのひとつ。そして、UnityでVRMを作成するのに必要なのがこのUniVRMです。
↑からダウンロードできるのですが、最新のバージョンだと、今回使用しているUnity 2019.4.31f1に対応していないので、ちょっと前のバージョンをインストールします。
今回の記事ではv0.99.4を使用します。
このファイルをダウンロードしてください。
![](https://assets.st-note.com/img/1677856412843-3zzkW2Pa8O.png?width=1200)
▶②UnityにUniVRMをインストール
Unityのプロジェクトを開いて、Assets>Import Packageから先ほどダウンロードしたUniVRMのファイルを選択します。
![](https://assets.st-note.com/img/1677856528855-kZCMXUr6Fa.png?width=1200)
するとこのウィンドウが開くのでImportをクリック
![](https://assets.st-note.com/img/1677856633259-ot6qG65cY6.png)
インストールに成功すると、この"VRM0"が表示されます。
![](https://assets.st-note.com/img/1677856796438-eYKyqoeI29.png?width=1200)
ここでプロジェクトをまた保存しておきましょう。
■ReadyPlayerMeでアバター作成
▶①顔写真からアバター作成
さて、いよいよReadyPlayerMeでアバターを作成します。公式サイトのココから作ってもいいのですが、
![](https://assets.st-note.com/img/1677859043494-1dbzPncLKe.png?width=1200)
なんだかこのデフォルトのアバタークリエイターは衣装のラインナップが少ない(?)気がします……。
筆者の方で開発者用のサブドメインを作ったので(ReadyPlayerMeは開発者登録すれば、無料で自分のアプリに埋め込むことができます)、よければ下からアクセスしてみてください。ちなみにご自分で開発者登録するのもそんなに難しくないですよ。
公式サイトと操作方法は同じですが、衣装のラインナップが多少多いようです。
アカウントは作っても作らなくてもOKです。とりあえず「Feminine(女性型アバター)」をクリックします。
![](https://assets.st-note.com/img/1677859280860-CoAfEOnyCO.png?width=1200)
つづいて、アバターの元になる写真を読み込みます。スマホなどを使っていてカメラが使える場合は「Take a photo(写真を撮る)」が使えますが、今回は事前に撮影した写真を使うので「Pick a file(ファイルを選択する)」を選びます。
※写真を使わず進む場合は「Continue without a photo」をクリック
![](https://assets.st-note.com/img/1677859313081-J9Z50Wj4yt.png?width=1200)
写真が読み込まれたらAcceptをクリック。
![](https://assets.st-note.com/img/1677859441578-sM5xIamGR1.png)
そして暫く待つと……アバターが出てくるのですが、まぁまぁ似てないです……笑 しかし、これを似るように仕上げるのが今回の目標なのでOKです!
![](https://assets.st-note.com/img/1677859466002-0RIvOuItfb.png?width=1200)
こんな感じでアバターはいじる事ができます。顔の形はこのあと修正するのですが、眉の形や髪の色、服などはここで確定させるので思い残すことのないようにします。
![](https://assets.st-note.com/img/1677859485329-GhP3zULo7L.png)
このあと輪郭などはフォトグラメトリで本人に限りなく近くなりますが、服装や目の色、眉の形などはここで決まるので慎重に選びましょう。
山川さんがShibu3 projectでガールズグループとしても活動されているということもあり、なんとなくそれっぽい感じ(?)にしてみました……
![](https://assets.st-note.com/img/1677858688639-BrrxsDNTF8.png?width=1200)
作り終えたらNEXTをクリック
![](https://assets.st-note.com/img/1677859596916-7fScdh7IgD.png?width=1200)
またアカウントを作成するかどうか聞かれます。いつでも再ダウンロードできるように保存したいなら、アカウントを作ってもいいですが、別に作らなくてもこのまま進めます。
![](https://assets.st-note.com/img/1677859801040-pNsDDXOFU5.png?width=1200)
ダウンロード用のURLが表示されるので、確実にコピーします。
▶②ダウンロード時に重要なこと
さて、モデルをダウンロードする時にとても重要なことがあります。
https://models.readyplayer.me/xxxxxxxxxxxxxxxx.glb
↑モデルのダウンロードURLはこのようになっているかと思うのですが
glbに続いて
?textureAtlas=none&morphTargets=ARKit,Oculus Visemes&pose=T
このように追記してダウンロードしてください!
↑こんな感じです。詳しい説明はココ↓にある通りですが
RPMでは開発者向けにいろいろと細かいオプションを用意しており、ダウンロードURLの末尾に指定の文字列を書くことでオプションを設定できます。
※オプション用の文字列は?で書き始め、複数のオプションを&でつなぐことができます。
細かい説明は端折りますが、上で記入した文字列の意味をザックリ解説するとこんな感じです。
textureAtlas=noneでテクスチャをまとめる機能(テクスチャアトラス)をOFFにします。テクスチャと一緒にパーツの分かれ具合が変わるのですが、分かれていたほうが後の作業がしやすいです。
![](https://assets.st-note.com/img/1677859898714-KzcUlTxVRv.png?width=1200)
morphTargets=ARKit,Oculus Visemesでデフォルトよりも表情や口パク、瞬きなどのアニメ(blendshape)が豊富になります。少ないと出来上がったアバターに表情がつきません。
![](https://assets.st-note.com/img/1677859897854-NT95YoMi6z.png?width=1200)
pose=tでDLしたアバターのポーズがTポーズになります。Tポーズの方があとの作業がしやすいです。
![](https://assets.st-note.com/img/1677859900307-m3Jeon2ENT.png?width=1200)
入力したアドレスにアクセスして、glbファイルをダウンロードして、すきな名前をつけておきます。
![](https://assets.st-note.com/img/1677860625870-OgL53iRlMM.png)
■面倒だけどこれはやっておく
▶①glTF Shell Extentionをインストール
さて、いよいよダウンロードしたアバターをblenderで編集していくのですが、最近glbファイルをblenderで扱うとテクスチャが変になる(blender内ではいいが、fbx出力時などに不都合が発生する)という事があるようです。たぶんいつか直るバグなのですが、念のため対策しておきましょう。
Microsoftのストアから↓をインストールします。ページ右上の「Microsoft Store アプリの取得」からインストールできます。
▶②ダウンロードしたglbファイルを展開
インストールができたら、ダウンロードしたglbファイルを右クリックして「Unpack to glTF」をクリックします。
![](https://assets.st-note.com/img/1677861148951-XxJXWXdVle.png?width=1200)
チェックを入れたままUnpackをクリックします
![](https://assets.st-note.com/img/1677861222689-eSxVQ2jAmU.png?width=1200)
するとこんな感じで、ひとつのglTFファイルと、その他テクスチャなどのファイルに解凍されます。
![](https://assets.st-note.com/img/1677861590251-454n3HCZo5.png?width=1200)
▶③展開したファイルをUnityの作成しておいたフォルダへ
前述の「アバターを入れるフォルダを作成してメモしておく」でメモしたフォルダに、展開したファイルをコピペします。これでバグ対策完了です!
![](https://assets.st-note.com/img/1677862129748-MgA8pn7gcY.png?width=1200)
■Blenderでアバターを開く
▶①いらんものを消す
Blenderを開いたら、マウスドラッグして中央の「Camera」「Cube」「Light」を選択して、Delキーで削除します。
![](https://assets.st-note.com/img/1677891612907-sZ7aa19PR2.png?width=1200)
▶②アバターをインポート
File>Import>glTF2.0を選択
![](https://assets.st-note.com/img/1677891740090-efNix30qav.png?width=1200)
前項でUnityのフォルダに保存したアバターを開きます
![](https://assets.st-note.com/img/1677891901531-NP8Gu0ITMr.png?width=1200)
最初はテクスチャが非表示なので
![](https://assets.st-note.com/img/1677892139557-fKr4NYyz2X.png?width=1200)
右上から表示モードを「Material Preview(マテリアルプレビュー)」に変更してテクスチャを表示します。
![](https://assets.st-note.com/img/1677892068511-gqrwGi9O7Z.png?width=1200)
基本操作はこんな感じです。アバターを眺めてみましょう。
マウスホイール:ズーム、ズームアウト
マウスホイールドラッグ:カメラ回転
Shift+マウスホイールドラッグで平行移動
▶③目と頭と歯のパーツを結合
ここからは前回の記事に詳しいのですが、以下のパーツを結合して、Zbrushにデータを受け渡す準備をします。
EyeLeft
EyeRight
Wolf3D_Head
Wolf3D_Teeth
右のメニューから、目玉のマークをクリックして表示・非表示を切り替えて、それぞれのパーツを確認していきます。
![](https://assets.st-note.com/img/1677892581683-PEVWt3pUPw.png?width=1200)
![](https://assets.st-note.com/img/1677892704454-6AbCCeuO0C.png?width=1200)
![](https://assets.st-note.com/img/1677892720577-EnJE4gjFNK.png?width=1200)
左上がObject Mode(オブジェクトモード)になっているのを確認して、それぞれのパーツをCtrlキーを押しながらクリックしていき選択。
![](https://assets.st-note.com/img/1677892854350-xPLqSPVtX5.png?width=1200)
Object>Joinをクリック
![](https://assets.st-note.com/img/1677892995542-WMoWojQsq4.png)
パーツがひとつにまとまりました!最後に選択したパーツに統合されるようです。
![](https://assets.st-note.com/img/1677907088157-9TH5X5KuXn.png?width=1200)
![](https://assets.st-note.com/img/1677893572020-4wlnAMDU9y.png?width=1200)
▶④Unityのフォルダにプロジェクトを保存
File>Save asを選択して
![](https://assets.st-note.com/img/1677893206866-T4R1EHgsKh.png)
作成しておいたUnityのフォルダに好きな名前を付けて保存します。
![](https://assets.st-note.com/img/1677893329847-oWl8uUpCYu.png?width=1200)
■Blender⇒Zbrush⇒Wrap3への受け渡し
▶①ZbrushにGoBで転送
Blenderで結合したWolf3D_Teethを選択して"Export"をクリック
![](https://assets.st-note.com/img/1677907217164-ejBLTRYWHu.png?width=1200)
すると、Zbrushが立ち上がり、該当のパーツがZbrushに転送されます。
![](https://assets.st-note.com/img/1677907278677-Hf2r3OaTtT.png?width=1200)
▶②ZbrushからOBJファイルを出力
ExportからOBJファイルを選択して好きな場所に保存します。ファイル名はそのまま(サブツール名と同じ)にしておきましょう。
![](https://assets.st-note.com/img/1677907349078-xFUkqWSuw3.png?width=1200)
▶③WrapでOBJファイルを読み込む
Wrap3を立ち上げ、右側のGraphにZbrushから出力したOBJファイルをドラッグアンドドロップで読み込みます。左側のタブを"Viewport3D"にすると表示されますが、ちょっとサイズが小さすぎるようです。
![](https://assets.st-note.com/img/1677907571126-vfgZiAIoTz.png?width=1200)
そこでScaleを30に設定しました。見失ったらFキーでフォーカスします。
![](https://assets.st-note.com/img/1677956727775-G45M3dyN79.png?width=1200)
ちなみに変な場所にあるんですが、これは動かさないように進めるのがオススメです(Zbrushに戻したときにメッシュの位置がズレることがあるので。回避方法はあるんですが、気を遣うのが面倒)
■Wrap3で作業
※使ったことない方は第8回の記事を参照ください!そちらで説目した基礎的な内容は頭に入っている前提で説明します。
▶①RCで作成したモデルを読み込んで並べる
第8回の記事の
▶STEP3 クリーンアップしたいメッシュを読み込む
▶STEP4 読み込んだメッシュを正しく表示する
▶STEP5 テクスチャを読み込む
▶STEP6 さらにピッタリ合わせる
こちらのステップを踏んで、読み込んだOBJファイルと、RealityCapture(RC)から出力したファイルを並べます。
参考までに、RigidAlignmentノードに使ったポイントはこんな感じです。
![](https://assets.st-note.com/img/1677906314042-K2jouhqWH3.png?width=1200)
並べ終えた状態はこんな感じになります。
![](https://assets.st-note.com/img/1677906371883-qa1W9VnI1n.png?width=1200)
このあとの作業の時、線がこんがらがるのを軽減するため、Zbrushから出力したほうのメッシュをコピペで複製しておきます。
![](https://assets.st-note.com/img/1677906789268-2hZ7nS3eX7.png?width=1200)
なお、テクスチャがあったほうが見やすければ先ほど生成されたtexturesフォルダの中にあるテクスチャをpaintで開いて…
![](https://assets.st-note.com/img/1677957304639-ryKOTYsHpt.png?width=1200)
「垂直方向に反転」させて…
![](https://assets.st-note.com/img/1677957419271-VdfZISYDzQ.png?width=1200)
赤矢印の部分に繋げばテクスチャが適用されます(うまくいかなければ、反転させずそのまま適用してみてください)
![](https://assets.st-note.com/img/1677957508061-HMqSMHTOZH.png?width=1200)
▶②Subsetノードを使う
さて、ここからは第8回の内容を超えたWrap使いの中級編です。じつは、この状態で第8回と同じようにWrapノードを使おうとしても上手くいきません。
![](https://assets.st-note.com/img/1677948835133-6Xn9uavPKq.png?width=1200)
試しにつないでみると「floating geometry~」というエラーが出ています。直訳すると「変形させようとしているメッシュに11の不連続なポリゴンコンポーネントが存在しています。1つである必要があります」という感じです。
![](https://assets.st-note.com/img/1677949059992-q3sBW4Ty49.png?width=1200)
Wolf3d_Teethはもともと3つに分かれているパーツを無理矢理ひとつにまとめたものなので、不連続な部分があるのは当たり前ですね。
細かなパーツに分かれているメッシュをWrapノードを変形させるときは、Wrapに使うパーツをひとつだけ選ぶ必要があります。この時に活用するのがSubsetノードです。
繋げ方はこんな感じです。Subsetノードをアバターのメッシュにつないで、間に「SelectPolygons」ノードをはさみます。
![](https://assets.st-note.com/img/1677949307802-WlZqLFODLP.png?width=1200)
SelectPolygonsノードを選択して、Visual Editorに移ったら、顔の部分のポリゴンをひとつクリックして"Grow(拡張)"ボタンを、赤い範囲が増えなくなるまでひたすら連打してください。
これで、連続しているポリゴンだけが選択されます。
![](https://assets.st-note.com/img/1677949369496-y7XqQMnAao.png?width=1200)
![](https://assets.st-note.com/img/1677949504696-iSYhpasrxV.png?width=1200)
あとは、第8回同様、SelectPointPairsをつないだうえでWrapします。
![](https://assets.st-note.com/img/1677949712383-7gQoeRiTR3.png?width=1200)
やり方を忘れた方は下記リンクを参照ください。
▶STEP7 いよいよWRAPしてみる
▶STEP8 Wrappingの精度を高める
![](https://assets.st-note.com/img/1677949921622-mQc98zGSqf.png?width=1200)
Wrapし終えると、このようになりました。
![](https://assets.st-note.com/img/1677949934975-G3j7AyOVHL.png?width=1200)
▶③Brushノードで形を整える
つづいて、Brushノードをこのようにつないで、メッシュの形を整えていきます。詳しくは下記リンクへ。
![](https://assets.st-note.com/img/1677950144028-6nOZS3aY6O.png?width=1200)
メッシュを表示する場合は元のWolf3D_TeethのWireframeにチェックを入れましょう。
![](https://assets.st-note.com/img/1677950191250-7yLSW8FnjJ.png?width=1200)
綺麗に仕上げるコツは、しっかりめにCloneブラシをかけることです。まずは目の周りから。動きに変化がなくなるまで、思い切りかけてOKです。
![](https://assets.st-note.com/img/1677950335753-NrcWWwdIu2.png?width=1200)
側面などもCloneブラシをしっかりかけていきます
![](https://assets.st-note.com/img/1677950413403-KxTAIyQgmM.png?width=1200)
頭もしっかりかけていきますが、このように後頭部がパッカリ割れているのは後から直るので気にしなくてOKです
![](https://assets.st-note.com/img/1677950452281-8lLPmb9owJ.png?width=1200)
口の裏側なども大きく変形している場合は軽くかけておきます
![](https://assets.st-note.com/img/1677950503031-h2k5aI14Uv.png?width=1200)
▶④LatticeノードでSubsetを元の形にもどす
さて、Subsetノードを使ったときに、下図のパーツは取り除かれてしまっています。これを元の位置に戻す、という作業が必要です。
![](https://assets.st-note.com/img/1677953256326-rb0FA1KQw2.png?width=1200)
ただ、SubsetはもうWrapで変形させてしまったので、このままでは元に戻せません。
![](https://assets.st-note.com/img/1677953309868-DZpZ2t0ndu.png?width=1200)
そこで役立つのがLatticeノード。変形後のSubsetに、除外されたパーツを適切な位置に戻してくれるのです。
![](https://assets.st-note.com/img/1677954628631-PgnBGNbsDs.png?width=1200)
こちらを参考にノードをつないでみてください。
![](https://assets.st-note.com/img/1677954878618-ZxMElzg6R7.png?width=1200)
※上級者向けの注意
後頭部の変化など見ると分かりやすいですが、Latticeノードを使うと「元のメッシュの構成に近づく」形でメッシュが多少、移動・変形します。超細かくBrushノードで位置を整えておいたりしても、Latticeを使うとある程度移動してしまうことは念頭に置いてください。
![](https://assets.st-note.com/img/1677955297312-usoxuye4XZ.png?width=1200)
▶⑤最後にもう一度brushをかけて保存
Latticeをかけたあとのモデルを精査して、問題があれば最後にもう一度だけBrushをかけます。超細かいですが、今回は唇のエッジがギザギザしているのを修正しました。
![](https://assets.st-note.com/img/1677955673067-WJ6poJsp3U.png?width=1200)
直すと唇がちょっと開いてしまうのですが、そこまで気にならないのでヨシとしました。
![](https://assets.st-note.com/img/1677955803818-nhxBjio2O3.png?width=1200)
納得いくまで修正できたら保存してOBJを出力します。
![](https://assets.st-note.com/img/1677956075267-4aXMkWaMb0.png?width=1200)
保存方法は下記の末尾にある通りなのですが、
▶STEP9-3 Brushノードで形を整える(RelaxProjブラシ)
2点注意があります。1点目はこの「Include Transform」のチェックを外すことです。
![](https://assets.st-note.com/img/1677956379309-MqeY50v16a.png?width=1200)
これを外さないと、最初の方でメッシュのscaleを30ほど大きくしたのが反映されて、うまくzbrushにメッシュをインポートできなくなります(位置がずれちゃいます)
![](https://assets.st-note.com/img/1677956727775-G45M3dyN79.png?width=1200)
2点目は、Zbrushから出力したときの、このサブツールとまったく同じ名称をキープすることです。
![](https://assets.st-note.com/img/1677956902031-tPrnZ1L136.png)
こうしないと、この先の過程が上手くいかなくなるからです。
![](https://assets.st-note.com/img/1677980197135-VdyeDPvHSC.png?width=1200)
OBJが保存できたら、ついでにプロジェクトも保存しておきましょう。
■変形したメッシュをblenderに戻す
▶①BlenderとZbrushの状態を確認する
※これまでの作業状態で、BlenderとZbrushが開きっぱなしの場合はそのまま②に進んでOKです(GoBでexport直前のBlenderのプロジェクトがUnityで作ったフォルダに保存されているかどうか、ダブルチェックしてくださいね)
Blenderを閉じてしまった場合は、一度Zbrushも閉じてあらためてExportボタンを押します
![](https://assets.st-note.com/img/1677980119264-qwHGhWnclT.png?width=1200)
Zbrushに正しくエクスポートされているのを確認します。
![](https://assets.st-note.com/img/1677983866355-CJ9P7BHtGf.png?width=1200)
▶②OBJファイルをBlenderに適用する
↑基本的にこれと同じことをします
GoBをImportモードにします
![](https://assets.st-note.com/img/1677984083654-S3KFWWUKRz.png)
Zbrushでexportしたサブツールをduplicateで複製します
![](https://assets.st-note.com/img/1677984217890-y88fp1iwP3.png)
複製したサブツールを選択した状態でImportをクリック、Wrapから出力したOBJファイルをインポートします
![](https://assets.st-note.com/img/1677984753133-jIDGJArtJH.png)
成功するとこんな感じになります。赤い部分がWrapからインポートしたメッシュで、赤黒い部分がWrap前のメッシュです。
![](https://assets.st-note.com/img/1677985046017-oPYTXgC2j4.png?width=1200)
モデルを眺めまわして、不都合が出そうなところが無いかチェックします。今回の場合、首の部分がもとより膨れていたので、このままインポートすると右のように服からハミでてしまいます。
![](https://assets.st-note.com/img/1677985327051-uZdPbunfhJ.png?width=1200)
そこで、Moveブラシを使ってハミ出そうな箇所をひっこめておきました。こうすれば後々、このようにキレイな仕上がりになります。
![](https://assets.st-note.com/img/1677985632182-AtYV6pUCxF.png?width=1200)
準備ができたらGoZをクリックします。
![](https://assets.st-note.com/img/1677985703147-RgYsqueeIJ.png)
すると修正が反映されました!
![](https://assets.st-note.com/img/1677985822009-0XWL1nFgek.png?width=1200)
修正前よりだいぶご本人に近づいたかと思います!
![](https://assets.st-note.com/img/1677986233455-J5NbbvDG5e.png?width=1200)
完了したら、BlenderのImportボタンはOFFにしておきましょう。
▶③結合したパーツを元に戻す(分離)
前回のこの項の応用です
いろいろ分離する順番は考えられると思いますが、以下筆者のオススメ。
まずはEditモードにして、表示をソリッドモードに切り替え。あと、表示パーツをこれから分離するものだけに。
![](https://assets.st-note.com/img/1677986962597-N4wT9jygGO.png?width=1200)
片方の目をクリックしてLキーを押し、選択範囲を目全体に拡張。
その後右クリック>Separate>Selection
すると、目のパーツが分離します。
![](https://assets.st-note.com/img/1677987254200-RLV3ePVfZo.png?width=1200)
同様に、もう片方の目も分離します
![](https://assets.st-note.com/img/1677987388139-cBG06Bf96E.png?width=1200)
同様に、頭のパーツの表面をクリックしてL。下図の範囲を分離します。
![](https://assets.st-note.com/img/1677987501826-Lhfuo7XLwj.png?width=1200)
上で顔の表面から分離された、この「Wolf3D_Teeth」パーツを単独表示にします(メニューの目玉アイコンをクリックして操作)
この耳の後ろ側に位置する2パーツを
左クリックドラッグ⇒Shiftを押したまま反対側も左クリックドラッグ
で両方選択して、またSeparate>Selection
![](https://assets.st-note.com/img/1677987638968-Fv6jmTR5dj.png?width=1200)
この歯のパーツの上にある、口上部のパーツを選択(矢印の一辺りをクリックすると上手くいきやすいかも)
![](https://assets.st-note.com/img/1677988762244-aMUoOrdMn8.png?width=1200)
Shiftキーを押したまま、口下部のパーツもクリック、Lキーを押して、赤い口の部分が上下とも選択されるようになったら、Separate>Selection
![](https://assets.st-note.com/img/1677988877739-Ar5xHjtLam.png?width=1200)
▶③結合したパーツを元に戻す(部分的に結合)
ここで一旦パーツの結合作業をするのでObject Modeに
![](https://assets.st-note.com/img/1677988340475-iYLCsAKb9A.png)
この顔表面のパーツ、耳の後ろ、口のパーツを結合します
![](https://assets.st-note.com/img/1677989303594-ALrqeeGdgF.png?width=1200)
それぞれのパーツをShiftキーを押しながら順にクリックしてJoinをクリック
![](https://assets.st-note.com/img/1677989422895-8tHPUEaVs5.png?width=1200)
こうしてひとつのパーツに結合されました
![](https://assets.st-note.com/img/1677989525886-BbUfTQlFaR.png?width=1200)
▶④消えたテクスチャを再設定
歯と舌のパーツ(Wolf3D_Teeth)のテクスチャが消えているので再設定します。
1.マテリアルプロパティ
2.ベースカラーの項目内をクリック
3.Image Textureをクリック
![](https://assets.st-note.com/img/1678002043751-vgSQs0FIDs.png?width=1200)
するとこういう状態になるので、Openをクリック
![](https://assets.st-note.com/img/1678002417068-McuzsFbOSR.png?width=1200)
Unityに保存したテクスチャの中から、このテクスチャを選びます(この場所のファイルを直接指定します)
するとテクスチャが設定されました!
![](https://assets.st-note.com/img/1678002473987-NGM81VPRjT.png?width=1200)
▶⑤パーツ名を元に戻す
名前が変わったパーツを元に戻します。矢印の箇所をダブルクリックして元の名前を設定してください。
![](https://assets.st-note.com/img/1678002800684-NRXZdoZj3t.png)
いちおう元の名前は下記のとおり
![](https://assets.st-note.com/img/1678002934318-Apm4YtP8Pe.png?width=1200)
![](https://assets.st-note.com/img/1678002985683-YvsBFutoxa.png?width=1200)
元に戻したあとはこんな感じです
![](https://assets.st-note.com/img/1678002715641-HzpdLGxk4Q.png)
ここまで来たら、プロジェクトを保存しておきましょう。
▶⑥FBXファイルを出力
File>Export>FBX
で、このアバターをFBX形式で出力します。出力先は、Unity側に作った、テクスチャを保存してあるフォルダを選んでください。
![](https://assets.st-note.com/img/1678003785931-mnaho0dUVp.png?width=1200)
無事に出力されました!
![](https://assets.st-note.com/img/1678003930387-DoinWiBIOG.png?width=1200)
出力すると、Unity側でこのようなメッセージが出ます。いまは細かいことはわからなくてもOKなので「Fix Now」で先に進んでください。
![](https://assets.st-note.com/img/1678003973516-5TZfJMAUDv.png?width=1200)
■UnityでアバターをVRM形式に変換する
▶①Rig設定をHumanoidに
出力したFBXファイルを、VRM形式に変換するために細かな設定をしていきます。まずは、Unityのフォルダから、さきほど出力したフォルダのFBXファイルを選択して、Rigタブから、Animation TypeをHumanoindにして、Applyで適用します。
![](https://assets.st-note.com/img/1678005656799-58AKEztJd5.png?width=1200)
▶②Material設定をUse External Materialsに
つづいてマテリアル設定です。Locationを"Use External Materials(Legacy)"に設定してApplyで適用します。
![](https://assets.st-note.com/img/1678005847611-y2Se4IN5ns.png?width=1200)
▶③FBXを配置
アバターをここにドラッグ&ドロップして、アバターを読み込みます。
![](https://assets.st-note.com/img/1678008220945-2eSm25uTJf.png?width=1200)
▶④VRM用のマテリアル設定を行う
こちらのMaterialフォルダを開いて
![](https://assets.st-note.com/img/1678008417698-zdkiOq51CO.png?width=1200)
フォルダ内のマテリアルをひとつクリック
![](https://assets.st-note.com/img/1678008518515-TrXsrdA3pW.png?width=1200)
ShaderをStandardから VRM>MToonに変更します。
![](https://assets.st-note.com/img/1678008656238-sObZi0dfQp.png?width=1200)
この表示になれば成功です。
![](https://assets.st-note.com/img/1678008708103-YAbuAdUqsZ.png)
すべてのマテリアルにVRM/MToonが設定されている状態にします。
![](https://assets.st-note.com/img/1678008801314-0agoTkOYnU.png?width=1200)
▶⑤UniVRMでアバターを出力する
設定を終えたFBXファイルを選択した状態で、
VRM0>Export to VRM 0.x を選択します
![](https://assets.st-note.com/img/1678008970178-KHuKX2MAoK.png?width=1200)
Exporterが起動して、入力必須な項目にエラー表示が出ます
![](https://assets.st-note.com/img/1678009301977-umMgEzwMAQ.png?width=1200)
ので、適当に入力してExportをクリックします。好きな出力先を選んで、VRMファイルの作成完了です!
![](https://assets.st-note.com/img/1678009272733-bDasTK3P7Z.png?width=1200)
▶⑥出力したVRMにアニメの設定をする
いまのままでもVRChatのアバターにできるのですが、いまのままだと一切顔が動かないアバターになってしまうのでアニメの設定をします。
さきほど出力したVRMファイルを、プロジェクトで使っているフォルダにドラッグ&ドロップします。
![](https://assets.st-note.com/img/1678010289539-LDNv8ZRHbG.png?width=1200)
するとVRMファイルが読み込まれていろいろフォルダが作成されました。一覧視しやすいように、右下のスライダーを左に移動させて、アイコン表示からリスト表示に切り替えます。
![](https://assets.st-note.com/img/1678010553964-Bqf3CCRSOu.png?width=1200)
そして、この水色の立方体アイコン(読み込まれたVRMファイル)をこちらにドラッグ&ドロップして読み込みます。
![](https://assets.st-note.com/img/1678010753568-f5YsKZ54cW.png?width=1200)
Assetsフォルダ内の「アバター名.Blendshapes」内の「Blendshape」をクリックします。
![](https://assets.st-note.com/img/1678010909379-1TWquvyrVL.png?width=1200)
すると、こちらのアニメ設定画面になります。この画面で、各状態のアニメを設定していきます。
最低限「A(あ)」「I(い)」「U(う)」「E(え)」「O(お)」と「Blink(瞬き)」が設定されていればいろいろ便利かと思いますが、ここではせっかくなので全部設定してみます。
![](https://assets.st-note.com/img/1678014649199-6vJWTSbE5R.png?width=1200)
たとえばですが「A」をクリックして
Wolf3D_Headの「Viseme_aa」を70くらい
![](https://assets.st-note.com/img/1678014423402-vc2ilTlc47.png?width=1200)
Wolf3D_Teethの「Viseme_aa」を100くらい
![](https://assets.st-note.com/img/1678014504929-ZvITKoh03i.png?width=1200)
に設定すると、下記のようになります
![](https://assets.st-note.com/img/1678014555335-EcwlKsZ1yA.png?width=1200)
Wolf3D_Teethの「Viseme_aa」=100
この調子でこれらの項目を全部設定していきます。お好きに設定すればよいですが、筆者の設定した値を記載しておきますのでご参考にどうぞ。
![](https://assets.st-note.com/img/1678014687224-rLEarxbLEo.png?width=1200)
![](https://assets.st-note.com/img/1678014843301-Au7J20o1hf.png?width=1200)
設定値無し
![](https://assets.st-note.com/img/1678017606513-BeBWfm0UHk.png?width=1200)
Wolf3D_Headの「Viseme_aa」=70
Wolf3D_Teethの「Viseme_aa」=100
![](https://assets.st-note.com/img/1678017678634-8w7xnEKbot.png?width=1200)
Wolf3D_Headの「Viseme_I」=70
![](https://assets.st-note.com/img/1678017746961-vVxsQY8ilo.png?width=1200)
Wolf3D_Headの「Viseme_U」=78
![](https://assets.st-note.com/img/1678017883325-vDTTBWP9OZ.png?width=1200)
Wolf3D_Headの「Viseme_E」=82
Wolf3D_Teethの「Viseme_E」=81
![](https://assets.st-note.com/img/1678017984170-PqsYaPE2NQ.png?width=1200)
Wolf3D_Headの「Viseme_O」=75
Wolf3D_Teethの「Viseme_O」=100
Wolf3D_Teethの「jawopen」=10
![](https://assets.st-note.com/img/1678018241953-1FOPLmOTHu.png?width=1200)
Wolf3D_Headの「eyeBlinkLeft」=100
Wolf3D_Headの「eyeBlinkRight」=100
※目が閉じきらないのはblenderで直せますが、瞬きに使うくらいならこの状態でも問題ないのでスルーします…
![](https://assets.st-note.com/img/1678018355120-rvZxg22Awa.png?width=1200)
Wolf3D_Headの「mouthSmileLeft」=25
Wolf3D_Headの「mouthSmileRight」=25
![](https://assets.st-note.com/img/1678025988748-GC9MNv2IA9.png?width=1200)
Wolf3D_Headの「browDownLeft」=100
Wolf3D_Headの「browDownRight」=100
Wolf3D_Headの「mouthPucker」=67
Wolf3D_Headの「cheekPuff」=48
![](https://assets.st-note.com/img/1678026174877-5Gvcy6URbk.png?width=1200)
Wolf3D_Headの「browInnerUp」=45
Wolf3D_Headの「mouthShrugLower」=16
Wolf3D_Headの「mouthRollLower」=100
![](https://assets.st-note.com/img/1678026318236-5MPzGSFpj8.png?width=1200)
Wolf3D_Headの「jawOpen」=32
Wolf3D_Headの「mouthSmileLeft」=30
Wolf3D_Headの「mouthSmileRight」=30
Wolf3D_Teethの「jawOpen」=26
![](https://assets.st-note.com/img/1678026496296-LsOPxJBMQ6.png?width=1200)
eyeLeftの「eyeLookUpLeft」=40
eyeRightの「eyeLookUpRight」=40
![](https://assets.st-note.com/img/1678026624457-ilQNWkC9fd.png?width=1200)
eyeLeftの「eyeLookDownLeft」=60
eyeRightの「eyeLookDownRight」=60
![](https://assets.st-note.com/img/1678026721258-3mAsLpLQaJ.png?width=1200)
eyeLeftの「eyeLookOutLeft」=67
eyeRightの「eyeLookInRight」=19
![](https://assets.st-note.com/img/1678026817279-xzdvlVx6G3.png?width=1200)
eyeLeftの「eyeLookInLeft」=19
eyeRightの「eyeLookOutRight」=67
![](https://assets.st-note.com/img/1678026934337-kQfo5pFQDW.png?width=1200)
Wolf3D_Headの「eyeBlinkLeft」=100
![](https://assets.st-note.com/img/1678027010542-SPQOXS5FSO.png?width=1200)
Wolf3D_Headの「eyeBlinkRight」=100
![](https://assets.st-note.com/img/1678005757932-aAJJLYLhoK.png?width=1200)
▶⑥再度UniVRMでアバターを出力する
アニメの設定が完了したらこの↓VRMファイルを選択して⑤とまったく同じように、もういちどUniVRMでVRMを出力します。
![](https://assets.st-note.com/img/1678027175450-OAz2remK0N.png?width=1200)
最後に、管理しやすいように別フォルダを作成して
![](https://assets.st-note.com/img/1678037751697-WtD6Whd8qi.png?width=1200)
出力したVRMファイルをドラッグ&ドロップ。必要なファイルやフォルダがまた生成されます
![](https://assets.st-note.com/img/1678037843777-guEdGuLKt3.png?width=1200)
これでVRChatにアップロードするVRMファイルは完成です!
■VRM Converter for VRChatを導入
いよいよVRMをVRChatにアップロードしますが、そのために下記のソフトをインストールします。
ここからインストーラーをダウンロードします(pixivアカウントが無い方は作成してからダウンロードします)
![](https://assets.st-note.com/img/1678027689139-dAdhwvFJM1.png)
ダウンロードした中身を解凍。Unityのプロジェクトを開いたままでいいのでダブルクリックします
![](https://assets.st-note.com/img/1678027743982-vfknHFnDwY.png?width=1200)
インストール用のウィンドウが開くのでImportをクリックすればインポート完了です。
![](https://assets.st-note.com/img/1678037201338-12AJM9GLWm.png)
■VRChatにアバターをアップロード
いよいよアバターをアップロードします。左上に読み込んでいたアバターはいったん消すと作業が分かりやすくなります
![](https://assets.st-note.com/img/1678038673008-XbN9l3BIN0.png)
最後に作ったVRMファイルをクリックして
![](https://assets.st-note.com/img/1678037924555-TRRybZMrq4.png?width=1200)
VRM0>Duplicate and Convert for VRChatを選択
![](https://assets.st-note.com/img/1678038004637-XUni4NSjBB.png?width=1200)
Duplicate and Convertをクリック
![](https://assets.st-note.com/img/1678038188719-vOLulCoyLU.png?width=1200)
アバターが読み込まれるので選択
![](https://assets.st-note.com/img/1678038746936-TtwJXCzliv.png?width=1200)
VRChat SDK>Show Control Panel
![](https://assets.st-note.com/img/1678038825080-xr6WevN5kg.png)
BuilderからBuild & Publish for Windows
![](https://assets.st-note.com/img/1678038919729-Odr6dH1sv1.png?width=1200)
こうなったら手前のウィンドウはもう閉じていいです
![](https://assets.st-note.com/img/1678039043709-m4zjGQjrm6.png?width=1200)
名前を入力してアップロードです
![](https://assets.st-note.com/img/1678039383417-E8Riek8Jco.png?width=1200)
※基本名前だけ入力すれば先に進めますが、詳細を知りたい方はこちらのサイトなど参考にどうぞ!
■VRChatでの動作テスト
アップロードしたアバターで動作テストをしてみました。御覧の通りちゃんともろもろの設定込みで反映されていました!
■反省など
さて、いかがでしたでしょうか。
想像以上に工程が長くなってしまい、実用性という観点では今ひとつかもしれませんが……ひとつひとつの工程の中に、少しでも皆さんの役に立つ部分がありましたら幸いです!