根据微信官方对外公开的消息,微信小游戏的脚步越来越接近了。它的开发者资格门槛和使用者门槛都很低,以后必将引爆一波"全民开发小游戏"浪潮。
官方的开发工具创建项目即可获取 `打飞机` 的源码,这是一个很小但五脏俱全的2D游戏,相信大多数嗅觉灵敏的程序员小哥哥们都已经体验并且亲手改造过啦。
但是如果你想借助微信的平台,做一个交互性、可玩性很强的 `联网游戏` ,就有一定的难度啦。,第一波流量红利你也能轻松抓住!这次教程我们就来讨论 **如何在完全不懂服务器开发的情况下做一个实时联网对战的微信小游戏** (联网飞机大战)。
为了能通读这篇文章,你最好:
已经掌握开发简单的微信小游戏,能看懂官方 打飞机 源码就行,甚至会用 Javascript 输出HelloWorld也行
略懂Java,其实不懂也行,在JS的基础上很容易引申,主要是要有 面向对象 的思想
下文重点都是讲如何快速上手开发 联网的微信小游戏 , 但 如果你懂得一些U3D开发,Bmob官方 也同时提供了 Unity3D版本的Demo+SDK,两者可以跨平台互通一起玩,且接口规范高度一致,基本上覆盖市面上所有的主流终端
PS:微信小游戏、Unity3D的SDK都是 开源 的,欢迎各位纠错
最简单的步骤获取 比目游戏云服务 (下称 官网)的账号,文章下方有获得方式;
在官网下载 微信小游戏Demo+SDK,导入到微信开发者工具(下称 工具),并修改AppKey;
在官网配置玩家同步属性,并发布下载的云端代码,然后在官网选择一个云服务器开启(PS:云服务器是免费的);
试运行Demo,如果console没有报错的话,点击工具的预览,用微信扫描二维码;
现在,就可以在游戏内创建房间,体验电脑与手机联网对战啦;
接下来大概介绍一下微信小游戏项目开发的要点,云端代码的详解和U3D版本的教程将陆续推出。
运行效果
左边的是 微信小游戏-开发者工具 的游戏页面,与右边的 Unity3D-MacOS-Editor 跨平台玩
运行效果如下:
https://www.bilibili.com/video/av21409295/
不得不说程序员自己来做UI真的丑得可以,那个"房间"界面真的无力吐槽
目前的Demo跨平台玩耍还有点小问题,例如玩家、怪物的移动速度不统一。但同平台对战是高度一致的。 这个问题与SDK没有关系,都是Demo本地项目的参数设置,主要是因为Unity项目都用的是绝对值,微信小游戏项目都是相对值,后续Unity也采用相对值的方式,完善Demo。
如何从零开发
论游戏开发的经验,相信各位读者中比我厉害的人多了去了。我这里就根据我个人的开发历程,围绕 联网飞机大战 这个项目,讲一下从零开发游戏的步骤吧。(嫌麻烦的可以不用看这一篇)
确定游戏主题、玩法;
理清多个客户端之间需要 同步的属性、互相通知的事件;
分析客户端与服务器需要 交互的事件;
制作/收集图片、动画、音效素材;
开发/照搬游戏世界的物理引擎,包括物体渲染、移动、碰撞检测(以及内存管理)等;
先开发服务端游戏逻辑(Java云端代码),有利于理清整个游戏的逻辑;
后开发客户端游戏逻辑、接入SDK;
测试、发布;
玩法:这个项目准备做成可以容纳超多人同时在线的飞机大战,所有设定基本上和微信小游戏官方Demo一样,增加了几个设定:
- 有四种造型、级别不同的Bot(有些人习惯称为 '电脑',也可以称为'飞机NPC') - 第3、4级的Bot可以开火,子弹(下称Fire)飞行速度与玩家一致,4级Bot的开火频率更高 - Bot有生命值(不再是一碰就死),分别是2、3、4、4,表示可以承受的Fire攻击次数 - Player(玩家)和Bot都分为两个阵营,阵营内无队友伤害 - Player的阵营由服务器随机划分,也可以改成玩家自己决定 - 刷怪逻辑放在云端,指定新产生的Bot的阵营、位置、类型 - Player受到伤害即淘汰,Fire碰到任何物体都消失 - Player之间、Bot之间、Player与Bot 如果发生碰撞,会同归于尽 - Player的开火暂时做成自动的,而不是按键开火 - Player的开火事件(开火坐标)是直接发送到其它客户端,不经过云端代码 - Player的淘汰交由云端处理,由云端校验后,再把该事件和胜负判定分发下去 - Bot的淘汰判定交由云端处理、分发 - 当某一方Player全部死亡时,另一方胜利;双方各剩一人时同归于尽则平局