data:image/s3,"s3://crabby-images/fc1fb/fc1fba7233676a29b56fc5b39560ce2b2d95f3aa" alt="見出し画像"
【VRChat】アイテムのWorld固定方法②
前回の記事
前回はWorld固定の基本的な設定をおこないました。
内容は前回からの続きとなりますので、まだ読んでない方は以下からどうぞ。
Animationの作成
前回作成したWorld固定の仕組みをExpressionメニューで動作するようにする為、Animationの作成とON/OFFによる切り替え処理を作成していきたいと思います。
作業の順番は、自分の癖でAnimatorのLayer作成後に、Animationファイルを作成していますが、どちらが先でも大丈夫です。
正直、Animationファイルを先に作った方が効率は良いかと。
1.AnimatorにParameterを追加
FXLayerを開きます。
FXLayerは、アバターオブジェクトに設定されている「VRC AvatorDescriptor」の「Playable Layers」にある「FX」のファイルをダブルクリックすれば、フォルダのどこにあるかわかると思います。
VRMからの変換であれば、「アバター名(VRChat).VRChat」フォルダ内に、購入アバターであれば、アバターフォルダの中にあるかと。
data:image/s3,"s3://crabby-images/395c7/395c73ae473033426bb4adad12ee681757f91133" alt=""
AnimatorタブのParameterにWeaponの表示とWorld固定用のParameterを追加します。
ここでは、「ActiveWeapon」「ActiveWeaponWorldFix」としておきます。
data:image/s3,"s3://crabby-images/133aa/133aa84b13552945fe2be4a78684e93a01e4eedd" alt=""
2.Layersの追加
続けてLayersタブに切り替えて、Weaponの表示とWorld固定用のLayerを追加します。
ここでは、ここでは、「Weapon」「WeaponWorldFix」としておきます。
Layer名は日本語でも大丈夫っぽいので、自分が見てわかりやすい名前にしておきましょう。
追加した2つのLayerの右の歯車マークをそれぞれクリックして、Weightを「1」にします。
これで、このLayerが有効化されます。
data:image/s3,"s3://crabby-images/b69c8/b69c85707469ff92afba630e7dd9106f7bee2664" alt=""
3.Stateを追加する
まずは「Weapon」のLayerをクリックし、Create State>Emptyをクリックします。
黄色いStateが追加されたら、続けてもうひとつ作成します。
もうひとつのStateはグレーです。
data:image/s3,"s3://crabby-images/f10d6/f10d6d66d0efdb42e4e263b4a9451880cf93f60a" alt=""
4.Write Defaultの解除
追加した黄色とグレートのStateをドラッグ(もしくは、Shiftを押しながら順番にクリック)して、選択状態にします。
続けて、右のInspectorから「Write Defaults」のチェックを外します。
data:image/s3,"s3://crabby-images/ac285/ac2855d2157fbef0dd9093890faea6e8f8391c28" alt=""
data:image/s3,"s3://crabby-images/aac82/aac82ec2e2f76e47ec47370ba27789ad6af51f4e" alt=""
5.Stateの名前を変更
Layer内の適当な箇所をクリックして、選択状態を解除します。
次に黄色のStateをクリックし、Inspectorの一番上のテキストボックスで、Stateの名前を変更します。
グレーのStateについても同様に名前を変更します。
ここでは、黄色Stateを「WeaponOFF」、グレーのStateを「WeaponON」としました。
Stateの名前もLayer名と同じく日本語でも大丈夫なので、自分で見てわかりやすい名前にしてOKです。
data:image/s3,"s3://crabby-images/eee08/eee08e323bed6df01256afb350fe39ec6cc9b2e4" alt=""
6.Transitionの作成
「WeaponOFF」のStateを選択し、右クリック>「Make Transition」を選択します。
矢印が表示されるので、その状態のまま、右の「WeaponON」をクリックします。
data:image/s3,"s3://crabby-images/2c4c1/2c4c11a5460a141e37f850c1e54408fad01affcf" alt=""
7.Transitionの詳細設定
作成したTransitionの矢印を選択し、Inspectorに表示されている内容を図のように設定してください。
・Has Exit Timeのチェックを外す
・Transition Duration(s)を「0」にする
・Conditionsの設定を「ActiveWeapon:true」にする
これで、ActiveWeapon Parameterがtrue(つまりON)になった時に、WeaponOFF→WeaponONに遷移するようになります。
後ほど説明するExpressionメニューからWeaponをONにした際に、ここの遷移が連動します。
data:image/s3,"s3://crabby-images/154da/154da4134ba0262961bdb0915adce2ac7a077b67" alt=""
8.小技:Transition設定コピー
今度は、逆にWeaponOFF→WeaponONへのTransitionの設定をしますが、ここで小技の紹介です。
Transition設定は、コピーペーストする事が出来るので利用しましょう。
Inspectorの「Transitions」のところで、右クリックし「Copy Transition Parameter」を選択してください。
data:image/s3,"s3://crabby-images/1a89d/1a89d7cc26fa5b0a5f6c85c2a23bba5ed581231f" alt=""
9.WeaponOFF→WeaponONへのTransition設定
コピーした状態を保持しつつ、
まずは先程と同じように、今度はWeaponON→WeaponOFFにTransitionを作成してください。
「WeaponON」のStateを選択し、右クリック>「Make Transition」です。
そして、作成したTransitionを選択し、InspectorからPaste Bothを選択すると、設定がコピーされます。
data:image/s3,"s3://crabby-images/7d2bd/7d2bd4541830248bf17631e71b735c6f87c5958e" alt=""
10.ペーストしたTransition設定の修正
ペーストしただけだと、WeaponOFF→ONと条件が同じになってしまうため、Conditionsだけ変更します。
・「ActiveWeapon:false」にする
このLayerは一旦これでOKです。
Animationファイルの指定は、のちほど説明します。
先にAnimationファイルを作っている場合は、このタイミングでセットしてOKです。
data:image/s3,"s3://crabby-images/ca63d/ca63d478fbc7997894fe8a056cb87cf87df7128a" alt=""
11.World固定用のLayer設定
今度はWorld固定用のLayerを設定します。
手順としては、WeaponのLayerと同じですので、詳細は省略します。
今回は、黄色Stateを「World固定OFF」、グレーのStateを「World固定ON」としました。
すでに記載した通り、Stateの名前は自分でわかりやすい名前にしてOKです。
注意として、Conditionsの利用Parameterが異なる事に注意です。
World固定のLayerには、「ActiveWorldWeaponFix」を使います。
・「ActiveWorldWeaponFix:true」にする
data:image/s3,"s3://crabby-images/d8f85/d8f8595860c97d0e763dfd414ac9881f2f43a1fc" alt=""
12.World固定ON→OFFのTransition設定
World固定ONの設定は下記です。
・「ActiveWorldWeaponFix:false」にする
data:image/s3,"s3://crabby-images/c1686/c1686a35dbff892d4d0cdfc5378ea758c3bb3d4c" alt=""
13.Animationファイルの作成
ようやくAnimationのファイルの作成です。
とはいえ、Layer作成よりは簡単です。
Projectタブの空いてる所(ファイルを置きたいフォルダ内)で右クリック>Create>Animationを選択してください。
作成されたAnimationファイル名は、ここでは「WeaponON」としておきます。
data:image/s3,"s3://crabby-images/cca59/cca59e1c69091bc1612299488e7608965d7908b6" alt=""
14.Animationの中身を定義する
Animationの定義をする際、やり方はいくつかありますが、個人的に簡単だと思ってる方法を紹介します。
まずは、Hierarchyからアバターをコピーします。
Windowsの場合は、アバターを選択して「Ctl + D」です。
基本的には、「アバター(1)」とかになるかと。
そして、先程作成した「WeaponON」Animationファイルをコピー作成したアバターにドラッグ&ドロップします。
画像だと、Kiruto(1)ですね。
data:image/s3,"s3://crabby-images/30a20/30a202f047cf6ab951742d532cc269de41b9461d" alt=""
15.Animationの録画
では、Animationを録画(中身を設定)します。
※Animationタブが表示されていない場合は、メニューのWindow>Animation>Animationで表示できます(下記画像①)。
data:image/s3,"s3://crabby-images/b7224/b722456037c5ea862c06cecbe3963b018b9c7eea" alt=""
次に、コピーしたアバターを選択した状態、Animationタブの表示が「WeaponON」になっている事を確認したら、赤丸ボタン(録画ボタン)をクリックします。
すると、赤いボタンが光り、録画状態になります。
この録画状態で操作した内容がAnimationとして定義される、という事です。
data:image/s3,"s3://crabby-images/70c7c/70c7cdb7377fa60b1a8919593fd6a666f9b1310e" alt=""
16.Weaponを表示するAnimationを録画
録画が始まりましたので、WeaponをON(表示)する処理をおこないます。
Weaponオブジェクトを選択し、Inspectorの名前の左にあるチェックボックスを2回クリックします。
一旦OFFにして、再度ONにする、という感じです。
すると、Animationに「Weapon:Game Object~」というキーが追加されているので、録画は完了です。
赤いボタンを再度クリックし、録画を終了します。
data:image/s3,"s3://crabby-images/1374b/1374b627ee8cf20ac18b80f05a31cba41b0a383c" alt=""
17.WeaponのOFFのAnimationを作成
次に、WeaponのOFF(非表示)のAnimationを作成します。
同じように録画する手もありますが、非常に面倒です。
なので作ったWeaponONのAnimationをコピーして、値だけ変える方法で楽をしましょう。
WeaponONのAnimationファイルを選択し、「Ctl + D」でコピーします。
名前は「WeaponOFF」としておきます。
続けて「WeaponOFF」ファイルをダブルクリックし、Animationタブに表示されたキー部分の値を「0」に変更します。
チェック表示だったり、数字だったりで分かりづらいですが、整理すると下記です(オブジェクトの表示/非表示に関して);。
・「チェックあり」=「1」=「Active」=「表示する」
・「チェックなし」=「0」=「NonActive」=「表示しない」
これで、「WeaponOFF」のAnimation設定も完了です。
data:image/s3,"s3://crabby-images/24858/24858336092b87be37f145535d78705a0de4fb18" alt=""
18.World固定用のAnimation作成
次にWorld固定用のAnimationを作成していきます。
手順としては、WeaponのON/OFF Animation作成と同じです。
今回は、OFFから作成します。
Animationファイル名は、ここでは「WeaponWorld固定OFF」としておきます。
data:image/s3,"s3://crabby-images/a4108/a4108824e1daae1a539561316dfdc29377b74dd4" alt=""
19.Weapon固定をOFFにするAnimationを録画
Animationタブの表示が「World固定OFF」になっている事を確認し、録画ボタンをクリックします。
録画が始まったら、アバター>WorldCenter>Weaponの「Parent Constraint」を2回クリックします。
Animationにキーが登録されたれ、録画を終了します。
data:image/s3,"s3://crabby-images/556c2/556c2c2f1e44deb5987b055b654d77ae25f1d88f" alt=""
20.World固定をONにするAnimationの作成
こちらもWeaponの表示OFFを作った時と同じ、Animationファイルをコピーして作成します。
「World固定OFF」Animationを「Ctl + D」でコピーします。
名前は「World固定ON」としておきます。
ファイルをダブルクリックして、値を「0」にします。
World固定の場合は、下記となります(Weapon表示ON/OFFと数値が逆になります。)
・「チェックあり」=「1」=「Parent Constraint:ON」=「World固定しない(右手に追随)」
・「チェックなし」=「0」=「Parent Constraint:OFF」=「World固定する」
Animationの作成はこれで終わりです。
複製したアバターは削除して大丈夫です。
data:image/s3,"s3://crabby-images/f3958/f395858cbb6cebb014462d9ce15f75ba8f595d47" alt=""
21.Animator LayerにWeaponON/OFF Animationを設定する
Animator Layerから「Weapon」Layerを開きます。
「WeaponOFF」Stateをクリックし、InspectorのMotionに作成した「WeaponOFF」Animationをドラッグ&ドロップします。
次に「WeaponON」Stateをクリックし、「WeaponOFF」Animationをドラッグ&ドロップします。
data:image/s3,"s3://crabby-images/63e40/63e40b24fa1ed9a423a99a5fe0cf5907b6be376f" alt=""
22.WeaponWorld固定ON/OFF Animationを設定する
続けて、World固定のLayerにAnimationを設定します。
WeaponON/OFFと同様に、それぞれのStateにAnimationファイルをドラッグ&ドロップします。
4つのStateにそれぞれ対応したAnimationが設定されている事を書くにしたらAnimatorのLayer設定は完了です。
data:image/s3,"s3://crabby-images/6f5e7/6f5e75d8f55e47f95bdf7dbaeb2f91f8876bc4af" alt=""
次回はExpressionメニューの作成
次回は、今回作成したWeapon ON/OFFとWorld固定 ON/OFFをExpressionメニューに追記する方法を説明していきます。