あなたの世界を作りなさい
プレイヤーとキャラクター: 上級
カメラコリジョンレイヤー
7 分
概要 zepetocameraはzepetoplayersを通じて作成され、camera collision設定を通じてカメラとゲームオブジェクト間の物理的衝突を制御できます。 camera collisionは、カメラがシーン内のオブジェクトと衝突することを指します。 camera collisionが設定されている場合、カメラがオブジェクトと衝突すると、そのオブジェクトの前に移動できず、カメラはオブジェクトの前に留まることになります。 次の2つの例を見てみましょう。 左側の画面では、camera collisionが設定されていないため、カメラはキャラクターや床の周りのオブジェクトに影響されずに自由に移動できます。 右側では、camera collisionが有効になっているため、カメラは移動中に壁や床を貫通することができません。 camera collisionを有効にすることで、カメラの動きが物理的に影響を受け、プレイヤーが見ることのできない場所はカメラによって照らされることがなく、よりリアルな描写が可能になります。 zepetoplayersカメラ衝突の設定 1\) カメラがレイヤーごとに検出する衝突を設定できます。 ユーザーレイヤーを設定または追加するには、インスペクタウィンドウのレイヤードロップダウンメニューを押して「レイヤーを追加」を選択します。 ユーザーが追加できるレイヤーは、layer3およびlayer6以上の番号が付けられます。layer0〜2およびlayer4〜5はunityのデフォルトレイヤーです。 2\) カメラが衝突判定を適用するオブジェクトを選択し、設定したレイヤーを選択します。 3\) 現在、zepetoplayersのカメラ部分で、衝突として登録したいレイヤーを選択するには、衝突のドロップダウンボタンを押します。追加したレイヤーを確認してください。 4\) 今、再生ボタンを押してランタイムを実行すると、zepetoカメラが床や壁を突き破ることなく移動するのが見えます。 ランタイムでスクリプトとして設定する 実行時にカメラの衝突を動的に指定できます。 以下は、実行時にレイヤーマスクとして公開変数として登録されたcollisionlayer番号を設定するスクリプトです。 重要なのは、zepetoplayers instance cameradata layerで選択されるレイヤーマスクを指定することです。 cameracollisionmanager import { layermask } from 'unityengine'; import { spawninfo, zepetoplayers } from 'zepeto character controller' import { zepetoscriptbehaviour } from 'zepeto script' import { worldservice } from 'zepeto world'; export default class cameracollisionmanager extends zepetoscriptbehaviour { // declare a public member to store an array of collision layer numbers public collisionlayer number\[]; start() { // create localplayer zepetoplayers instance createplayerwithuserid(worldservice userid, new spawninfo(), true); // add an event listener for when the local player is added to the scene zepetoplayers instance onaddedlocalplayer addlistener(() => { // set the camera collision layer to the new layer mask zepetoplayers instance zepetocamera collisionlayer = this setnewlayermask(); }); } // method to create and set a new layermask based on the collision layers private setnewlayermask() layermask { let layermaskvalue = 0; // iterate through the collision layers array and update the layer mask value this collisionlayer foreach(layernumber => { layermaskvalue |= 1 << layernumber; }); // create a new layermask and set its value to the calculated layer mask value let newlayermask layermask = new layermask; newlayermask value = layermaskvalue; return newlayermask; } } 3\ スクリプトの説明 レイヤーをスクリプト化し、それをカメラに適用するためには、layermaskを使用する必要があります。 layermaskはビット演算を通じて入力された値を持ちます。 layermaskは整数値として表され、各ビットはレイヤーが含まれているかどうかを示します。 例えば、layermaskの値が5(2進数で00000101)の場合、レイヤー0とレイヤー2が含まれていると言えます。 layermaskvalue |= このビット演算は、既存のlayermaskvalueと新しく計算された値をor演算で結合します。 既存のlayermaskvalueが2進数で00000001で、新しく計算された値が00000100の場合、2つの値をorすると2進数で00000101になります。 これにより、レイヤー0とレイヤー2の両方がlayermaskに含まれることが保証されます。 📘 unity layer mask https //docs unity3d com/2020 3/documentation/scriptreference/layermask html https //docs unity3d com/2020 3/documentation/scriptreference/layermask html enhancedcameraの場合、プレイヤーレイヤーはカメラの衝突レイヤーに設定されておらず、カメラがキャラクターと交差しないようにしています。