多人游戏
ZEPETO 多人游戏是一个模块,允许多个用户同时连接并玩这个世界。
它提供了服务器/客户端开发和本地测试环境。
📘 官方多人游戏世界示例
在 [项目] 面板左上角的 [+] 菜单中选择 ZEPETO → 多人游戏服务器,或转到资产 → 创建 → ZEPETO → 多人游戏服务器。
World.multiplay 包含以下项目,并在世界发布时自动更新。
- index.ts:服务器主要逻辑代码
- schemas:服务器/客户端通信的数据结构
❗️ 注意
每个游戏只能创建一个 World.multiplay 包。
点击下图所示的 [打开世界设置] 以设置世界设置。
属性 | 描述 |
---|---|
版本 | 输入要注册的文件版本。 |
最大客户端数 | 设置可以访问房间的最大人数。 |
方向 | 选择屏幕的方向。 |
禁用邀请 | 禁用房间邀请功能。 |
禁用房间列表 | 禁用查看房间列表的功能。 |
禁用私人房间 | 禁用创建私人房间的功能。 |
👍 禁用邀请
即使房间邀请功能关闭,您仍然可以通过测试链接发送邀请。
ZEPETO Multiplay 提供了一个本地服务器环境,创作者可以在开发过程中测试服务器/客户端。
要检查本地服务器操作,请选择 Unity 顶部菜单 → 窗口 → ZEPETO → 多人服务器,以打开服务器状态窗口。
点击编辑器屏幕中央 [▶︎(播放)] 按钮旁边的服务器按钮。
您将在服务器状态面板中看到以下服务器日志。
ZepetoWorldMultiplay 组件是一个用于客户端的多玩家管理类。
在层级窗口中创建一个 GameObject,并添加 ZepetoWorldMultiplay 组件。 ZepetoWorldMultiplay 组件将自动连接到多玩家包。
点击编辑器屏幕中央的[▶︎(播放)]按钮,以查看服务器日志窗口中的客户端连接日志。
开发服务器运行在localhost(127.0.0.1),端口在项目首次加载时设置。
通过多项目连接时,将连接环境设置为以下内容
📘 请参考以下指南 访问多人游戏IP地址
👍 世界分发后,将在ZEPETO服务器上运行。
实现服务器逻辑
World.multiplay 包中的 index.ts 文件是负责服务器主要逻辑的代码。
打开 index.ts 文件,并在 onCreate() 事件中添加在接收到消息类型 echo 后发送给客户端的逻辑。
📘 请参考以下指南 [Zepeto.Multiplay(服务器) API]
实现客户端逻辑
在用于发送/接收服务器事件的 ZepetoWorldMultiplay GameObject 中创建并添加 ZEPETO 脚本,如下所示:
📘 请参考以下指南 [err]
点击编辑器屏幕中央的 [▶︎(播放)] 以运行服务器/客户端。您应该会看到如下所示的 'echo' 类型消息示例:
① 客户端消息在服务器接收时的输出日志。
② 从服务器接收到的客户端消息日志。
❗️ 注意
[服务器代码中变量的使用]
- 变量也可以在服务器代码中声明。
- 但是,服务器中可用的缓存内存目前限制为512KB。(这可能会在以后改变。)
- 如果超过512KB,房间可能会被隐藏,因此请在开发时考虑这一点。
[服务器代码中循环的使用]
- 在服务器代码中,循环时间限制设置为2秒(2000毫秒)。
- 请在开发时考虑这一点,因为使用阻塞代码或长时间运行的循环可能会导致程序无法正确执行,因循环时间限制。