创造你的世界
多人游戏
13min
zepeto 多人游戏是一个模块,允许多个用户同时连接并玩这个世界。 它提供了服务器/客户端开发和本地测试环境。 📘 官方多人游戏世界示例 github https //github com/naverz/zepeto multiplay example https //github com/naverz/zepeto multiplay example 教程 创建多人游戏 docid\ spk tardrdz3td3r6gnae 步骤 1 安装 在 \[项目] 面板左上角的 \[+] 菜单中选择 zepeto → 多人游戏服务器,或转到资产 → 创建 → zepeto → 多人游戏服务器。 world multiplay 包含以下项目,并在世界发布时自动更新。 index ts:服务器主要逻辑代码 schemas:服务器/客户端通信的数据结构 ❗️ 注意 每个游戏只能创建一个 world multiplay 包。 步骤 2:设置 点击下图所示的 \[打开世界设置] 以设置世界设置。 属性 描述 版本 输入要注册的文件版本。 最大客户端数 设置可以访问房间的最大人数。 方向 选择屏幕的方向。 禁用邀请 禁用房间邀请功能。 禁用房间列表 禁用查看房间列表的功能。 禁用私人房间 禁用创建私人房间的功能。 👍 禁用邀请 即使房间邀请功能关闭,您仍然可以通过测试链接发送邀请。 步骤 3 运行测试服务器 zepeto multiplay 提供了一个本地服务器环境,创作者可以在开发过程中测试服务器/客户端。 要检查本地服务器操作,请选择 unity 顶部菜单 → 窗口 → zepeto → 多人服务器,以打开服务器状态窗口。 点击编辑器屏幕中央 \[▶︎(播放)] 按钮旁边的服务器按钮。 您将在服务器状态面板中看到以下服务器日志。 步骤 4 连接到客户端(连接到本地服务器) zepetoworldmultiplay 组件是一个用于客户端的多玩家管理类。 在层级窗口中创建一个 gameobject,并添加 zepetoworldmultiplay 组件。 zepetoworldmultiplay 组件将自动连接到多玩家包。 点击编辑器屏幕中央的\[▶︎(播放)]按钮,以查看服务器日志窗口中的客户端连接日志。 开发服务器运行在localhost(127 0 0 1),端口在项目首次加载时设置。 通过多项目连接时,将连接环境设置为以下内容 📘 请参考以下指南 访问多人游戏ip地址 docid\ oa elwpl9vtgeqcrjk1g4 👍 世界分发后,将在zepeto服务器上运行。 步骤 5 服务器 / 客户端通信默认示例 实现服务器逻辑 world multiplay 包中的 index ts 文件是负责服务器主要逻辑的代码。 打开 index ts 文件,并在 oncreate() 事件中添加在接收到消息类型 echo 后发送给客户端的逻辑。 📘 请参考以下指南 \[zepeto multiplay(服务器) api] import { sandbox, sandboxoptions, sandboxplayer } from 'zepeto multiplay'; import { player } from 'zepeto multiplay schema'; export default class extends sandbox { oncreate(options sandboxoptions) { this onmessage("echo", (client, message) => { console log(`echo onmessage from ${client sessionid}, > ${message}`); // 发送给当前客户端 client send("echo", "发送给发送者 " + message); // 广播给所有连接的客户端 this broadcast("echo", "发送给所有人 " + message); }); } onjoin(client sandboxplayer) { const player = new player(); player sessionid = client sessionid; player userid = client userid; const players = this state players; players set(client sessionid, player); console log('onjoin!!!!'); } onleave(client sandboxplayer, consented? boolean) { } } 实现客户端逻辑 在用于发送/接收服务器事件的 zepetoworldmultiplay gameobject 中创建并添加 zepeto 脚本,如下所示: multiplaysample ts import { zepetoscriptbehaviour } from 'zepeto script'; import { zepetoworldmultiplay } from 'zepeto world'; import { room } from 'zepeto multiplay'; export default class multiplaysample extends zepetoscriptbehaviour { private multiplay zepetoworldmultiplay; start() { this multiplay = this gameobject getcomponent\<zepetoworldmultiplay>(); this multiplay roomjoined += (room room) => { console log(`roomcreated, my session id is ${room sessionid}`); // 发送消息到服务器 room send("echo", "你好 zepeto 多人游戏"); // 添加服务器消息监听器 room addmessagehandler("echo", (message) => { // 打印服务器消息 console log(message); }); }; } } 📘 请参考以下指南 \[err] docid\ dcvlxu1sleipbvr2qkuiu 步骤 6 测试输出结果 点击编辑器屏幕中央的 \[▶︎(播放)] 以运行服务器/客户端。您应该会看到如下所示的 'echo' 类型消息示例: ① 客户端消息在服务器接收时的输出日志。 ② 从服务器接收到的客户端消息日志。 使用服务器代码时的注意事项 ❗️ 注意 \[服务器代码中变量的使用] 变量也可以在服务器代码中声明。 但是,服务器中可用的缓存内存目前限制为512kb。(这可能会在以后改变。) 如果超过512kb,房间可能会被隐藏,因此请在开发时考虑这一点。 \[服务器代码中循环的使用] 在服务器代码中,循环时间限制设置为2秒(2000毫秒)。 请在开发时考虑这一点,因为使用阻塞代码或长时间运行的循环可能会导致程序无法正确执行,因循环时间限制。