目次
1.準備
2.スイッチの処理を書く
3.動作確認する
4.解説
?.おまけ(Nullチェック)
VCCバージョン2.1.3、Unityバージョン2019.4時の状況で解説してますが、VCCの大規模アプデが来ない限り2022になっても大して変わらないと思います。
プロジェクトの準備やU#の準備がそもそも分からないという方は、以下の記事を参考にしてみてください。
1.準備
スイッチ用のキューブを設置
まず前回の記事同様に、Cube
をワールドに置きます。
このCubeはスイッチとして扱うので、大きさはXYZ共に0.2くらいにしましょう。
ミラーの設置
Projectフォルダでmirror
と検索すると「VRCMirror」というプレハブが見つかるのでこれをシーンに置きましょう。
検索しても見つからない時はVRCWorldプレハブの時同様、Search:
の右がAll
になっていることを確認しましょう。
スクリプトの作成
今回はオブジェクトの切り替え役を作るので、ファイル名はObjectSwitch
などにしましょう。
2.スクリプトを書く
ObjectSwitch.cs の中身を書いていきます。
後から解説するので、一旦コピペで良いです。
using UdonSharp;
using UnityEngine;
using VRC.SDKBase;
using VRC.Udon;
public class ObjectSwitch : UdonSharpBehaviour
{
// 対象オブジェクト
[SerializeField] private GameObject _targetObject = null;
// スイッチが押されたら動作する
public override void Interact()
{
// 表示/非表示を切り替える
_targetObject.SetActive(!_targetObject.activeSelf);
}
}
書き終わったら、Ctrl + S
で保存です。毎回言います。
3.動作確認する
処理をスイッチにアタッチする
前回の記事でやったようにCube
にUdon Behaviour
というコンポーネントを追加し、Program Source
にObjectSwitchをアタッチします。
ここまでは前回と同じです。
ObjectSwitch (U# Script)
の下側にあるTargetObject
に、VRCMirror
プレハブをアタッチします。
これで準備完了です。再生ボタンを押して動作確認してみましょう。
スイッチをクリックするとミラーの表示を切り替えれるはずです。
4.解説
変数
ではまず上から...
// 対象オブジェクト
[SerializeField] private GameObject _targetObject = null;
長ったらしく書いてますが、ここはGameObjectを入れる箱を用意しています。
GameObjectを入れる為の箱を用意するよ。箱の名前は_targetObjectね。
ってかんじです。
このような箱のことを、変数といいます。
整数ならint、少数ならfloat、文字列ならstring、オブジェクトならGameObject型といった、型が必ず必要です。
その先頭に [SerializeField] を付けると、インスペクターにこの箱が空の状態で現れます。
試しに [SerializeField] を消してUnityEditorに戻ると、TargetObjectの欄は消えてると思います。
↑を試した人は、忘れずに削除した文字を書き直し、UnityEditorに戻って、VRCMirror
をアタッチする作業をしなおしてください。
ちなみに以下の書き方でも同じことができますが、個人的には [SerializeField] private ... の方が好きです。
(ゲーム開発者の人はそうですよね??)
// 対象オブジェクト
public GameObject _targetObject = null;
Interact
続いて実際のスイッチの処理です。
// スイッチが押されたら動作する
public override void Interact()
{
...
}
Interact() の中は、このオブジェクトがUseされた時に処理されます。
この中にオブジェクトの表示/非表示の処理を書けば、スイッチとして動作させることが可能です。
// 表示/非表示を切り替える
_targetObject.SetActive(!_targetObject.activeSelf);
SetActive
gameObject.SetActive()には、trueかfalseを入れることでそのオブジェクトのアクティブ状態を変えることができます。
trueかfalseかが入る変数の型を「bool型」と言います。
ON/OFFの切り替えでよく使われます。
アクティブにする場合
gameObject.SetActive(true);
非アクティブにする場合
gameObject.SetActive(false);
アクティブ状態って何? というと、みなさんがUnityでよく見るこのチェックマークです。
チェックが付いてると表示。何もなかったら非表示になるアレです。
動作確認をしながらVRCMirror
のインスペクターを見てると、ここのチェックが切り替わっているのが分かると思います。
gameObject.activeSelf は、そのオブジェクトのアクティブ状態をbool型で教えてくれます。
それの先頭に!
をつけると、bool型を反転してくれます。
これで表示/非表示を切り替える仕組みになっています。
?.おまけ
Nullチェック
今回は初心者がよくしがちな、あるあるなエラーとその対処について書きます。
アタッチし忘れ。です。
まず、スイッチ役のCubeのTargetObjectにアタッチされているミラーを外しましょう。
そして実行してスイッチを押してみると、ミラーのアクティブが切り替わりません。
Consoleウィンドウにはエラーが出ています。
Udonがこのようにエラーを吐くと、そのギミックは二度と動きません。
試しにスイッチをもう一回押しても、エラーはこれ以上増えません。
今回のような簡単な処理ではあまり気になりませんが、今後大きいギミックを作る際には、途中でエラーを吐いても動作はし続けるようにする必要があります。
今回のエラーの内容は、「SetActiveしようとしたけど、その対象のオブジェクトがNullだよ(無いよ。)」です。
じゃあ、オブジェクトが無くても処理が動くようにしましょう。
Nullでも動くように、コードを修正
// スイッチが押されたら動作する
public override void Interact()
{
// _targetObjectの中身がnullじゃない時に処理する
if (_targetObject != null)
{
// 表示/非表示を切り替える
_targetObject.SetActive(!_targetObject.activeSelf);
}
else
{
// ログを出力する
Debug.Log("TargetObjectがアタッチされていません。");
}
}
以下の書き方でも同じ動作になります。
// スイッチが押されたら動作する
public override void Interact()
{
// _targetObjectの中身がnullだったら、ここで処理を終える。
if (_targetObject == null)
{
// ログを出力する
Debug.Log("TargetObjectがアタッチされていません。");
return;
}
// 表示/非表示を切り替える
_targetObject.SetActive(!_targetObject.activeSelf);
}
コピペしたらCtrl + S
。絶対。
これで実行すると、エラーの代わりに自分で書いたログが出力されます。
エラーで止まることも無いので、何回押してもログが出力されます。
Debug.Log()はEditorでしか確認できませんが、処理がどこまで走っているかを確認したり、変数の動きを確認したりできます。
便利なので最初のうちはガンガン使いましょう。
慣れてきたと思ったら、偶に使うくらいが良いかも。