あなたの世界を作りなさい
プレイヤーとキャラクター: 上級
テレポート実装
9min
ZEPETOキャラクターが2つの異なるポイントにテレポートできるポータルを実装します。
data:image/s3,"s3://crabby-images/22026/22026f55335ecde8b37d6d08a4c78a617dc6fdbb" alt="Document image Document image"
- シーンにZEPETOキャラクター作成コードをデフォルトとして実装します。
📘 以下のガイドを参照してください。[ZEPETOキャラクターを作成する]
1) テレポートするポイントを作成します。
- このガイドでは、これらをAポイントとBポイントと呼びます。
- 階層を作成 > 3Dオブジェクト > プレーンを作成し、Plane_Aに名前を変更します。
data:image/s3,"s3://crabby-images/50bc0/50bc0b8bf61baa05fd046d52f60017964aa51f68" alt="Document image Document image"
2) テレポートを開始するポータルオブジェクトを追加します。
- オブジェクトと相互作用するためにコライダーを追加してください。
- 衝突を検出するためのエリアのサイズを調整します。
- Is Triggerを確認してください。
data:image/s3,"s3://crabby-images/e0f9b/e0f9b9a224c8939461dcbeec99c71de009c3cc33" alt="Document image Document image"
3) 同様の方法で合計2つのテレポートポイントを作成します。
data:image/s3,"s3://crabby-images/065c5/065c54df12061a6b489f76b6ae43c7d2da450676" alt="テレポートポイントAの例 テレポートポイントAの例"
テレポートポイントAの例
data:image/s3,"s3://crabby-images/a5726/a57265c68adfda342b518095dd3a48a7c727bca0" alt="テレポートポイントBの例 テレポートポイントBの例"
テレポートポイントBの例
- ポイントが重ならないように位置を調整します。
data:image/s3,"s3://crabby-images/fb27a/fb27ac8d3ee0c38154b1dfd46fade1a4d5c660d7" alt="Document image Document image"
1) プロジェクトを作成 > 作成 > ZEPETO > TypeScript として名前を Teleport に変更します。
2) 以下のようなサンプルスクリプトを書きます。
- スクリプトがアタッチされているオブジェクトのコライダーエリア内でZEPETOキャラクターとの衝突が検出されたときに、destinationObjectとともにテレポートするロジック。
3) スクリプトの記述が完了したら、テレポートを開始するポータルオブジェクトにスクリプトを追加します。
4) インスペクターで、Destination Object を割り当てます。
- Destination Object : テレポートの終点に到着するポータルオブジェクト。
data:image/s3,"s3://crabby-images/d6f37/d6f3799125fbb9a1312d9d89c6292db15c1eae74" alt="Document image Document image"
ポータルの近くにいるときに、ZEPETOキャラクターをポイントAからポイントBにテレポートします。
data:image/s3,"s3://crabby-images/4a2fb/4a2fb81afd86e83a9667111d03756e2596f63799" alt="Document image Document image"
- このガイドは、私が操作するローカルプレイヤーのテレポートのみを扱います。
- マルチプレイヤーの世界の場合、他のプレイヤーの位置の同期が追加で必要です。
- マルチプレイヤーサンプルの同期コンポーネントを使用すると、位置の同期が簡単に実装できます。
📘 マルチプレイサンプル - Zepetoマルチプレイコンポーネント https://github.com/naverz/zepeto-multiplay-example/tree/main/Assets/Zepeto Multiplay Component