Cocos Creator |《飞刀大乱斗》开发教程

95cf57d2f537f0b809802a5cceadee4c.gif

本篇文章转载自公众号【一枚小工】,作者:一枚小工

本篇文章为大家带来 Cocos Creator 飞刀大乱斗开发系列教程。

5e12c40852ee573a323ef48640d15736.png

one 1

主页下方列表选项如何实现

9bbd09f635efd93529774dfeaee6ed06.gif

预览效果

一、具体内容

游戏开始后,加载所有现有的英雄列表,这一功能的实现,如下图部分。

233d17507ab92d00676d845b71a1229c.png

列表使用 ScrollView 实现,横向滚动,设置好上下左右的边距、选项之间的间距,内容部分使用 Layout 来做自动排版,最终列表显示内容,如上图所示即可。

重点是列表中的英雄预制体。预制体一共有三种状态:已解锁、使用中、未解锁。具体显示效果如下图所示。游戏中存储每一级英雄的状态,根据状态数据,绘制英雄列表显示。

cd3d9d56381d29e5afae68040e3b22f0.png

二、状态的显示控制

如上所述,一共有三种状态,理论上,游戏开始时,只有第一关是解锁的,后面的关卡根据游戏的进行,不断的开启。预制的状态由一个变量控制,不同值表示不同状态。

6e00d4d72ceb244dd7bfe5ec53990f2e.png

预制节点下,留有不同状态的根节点,根据英雄不同的状态,控制不同状态的节点显示以达到状态变化的效果。

44f0c029654367c26f289ceb918aba9d.png

三、英雄武器显示控制

9c020491ed70d31a22b0e7ce50c54227.jpeg

d86783b4d2dcfdd9f7b07f7f19cc1d98.png

武器和英雄,都依托在一个精灵上,对应的纹理,使用纹理数据存储即可,为了方便,会按照等级顺序存储,这样方便取出等级纹理图片。

ad9d82e0cb59d227ce8e4a75922e7e1e.png

四、英雄选择控制

因为在游戏过程中,一次只能使用一个英雄,所以使用中状态的英雄,永远只会有一个。而且,未解锁的英雄,是无法使用的,点击也需要做特别处理。

8a363e13d3286a273554699a459cc2db.png

如上图代码,在选择的时候,需要判断新选择的是否和之前的一样,这种不需要做处理;如果获取到新选择的英雄未解锁,目前是没有做其他任何处理的。

添加英雄的时候,需要给每个预制体注册一个回调函数,预制体点击的时候,会调用注册的函数,为了获取点击的节点,需要把预制体本身节点传递出来。

五、加载英雄列表

游戏一开始,根据英雄列表数据,绘制英雄列表,数据单机的,存储在内存。存储的数据包括:各等级的英雄名称,状态信息,后续游戏过程中,触发某些条件,再更新对应数据,重新绘制列表即可,如果有需要,也可以存储起来,目前是用来学习的 demo,就暂时用全局变量存储。

d5a5b657304ea6a95a7cf6a0de55bfab.png

two 2

主页中间人物效果的实现

710d17b5ed157406862935ae0fc62fe4.gif

预览效果

一、具体内容

也就是在下方列表选择不同人物,上方显示不同的人物,播放不同的效果,即下图的效果实现,此部分也是采用预制 Prefab 进行实现。

1524ad8a26544ca4877ac81064c3a551.gif

二、英雄 Hero 预制组成

英雄预制 Hero 主要四部分组成:旋转的光、大小变化的光球、英雄本身、英雄的武器。这四部分,都会根据英雄的不同等级,动态的更换对应的纹理即可,游戏过程中,使用的动画,无须变化。

f6f3da340f7e9c5993c9439b65b2e00e.jpeg

使用到的几个精灵,都需要根据不同等级,进行纹理的更换,于是就封装了一个通用的方法,传入精灵节点和纹理所在路径,使用 cc.loader 动态加载纹理,加载成功以后,直接显示出来。

130eea80a466dd16ae4bef79d3e0d4ea.jpeg

三、动画的显示

83cee93998f9eaf5e98b9878dd67704a.jpeg

光旋转效果,只需要做旋转动画即可。在动画中,加入旋转角度,就可以简单的实现。显示的效果好不好,可以预览观察,直到调整到合适的旋转节奏就行。

6072f48e67afa522b0f05514a4f7b3ef.gif

武器旋转效果,和旋转的光,是用的同一种节奏进行的,所以本实例中,旋转的武器和旋转的光,都是使用上图效果中的同一个动画。播放时,设置成循环播放就可以实现不断的播放效果了。

放大缩小光球,也和上面动画效果差不多,只是动画选择的是 scale 属性,不断的进行放大缩小就行,也是一样,加入循环播放的控制。

3468f9ff5054c7f9e72bcd1eaaab0546.gif

以上所有动画,在游戏中是同时进行播放的,最后看起来的效果就如同最开始的预览一样,球和武器一起旋转,同时光球不断的放大缩小。

四、武器添加

这里将的武器添加,是指初始化时,根据不同等级的英雄,默认添加添加到英雄周围旋转的飞刀,都是一次性添加的,没有动态添加几把的效果,这个后期会讲到。

3254aa7f8c9dfb587a49ac2f85081569.png

英雄上所有的武器,共用一个根节点,根节点作为容器,管理所有武器。这么做的好处是,多个武器需要做动画时,只需要按照规则把武器添加好,对根节点做动画即可。添加的方式是,以中心点为圆点,根据武器数,计算出每把武器之间的角度,然后算出每把武器的 x 坐标值和 y 坐标值。

4fd0c9564a7c2891377ddd64eddc30b5.jpeg

假设武器锚点离中心点的偏移量是 Offset,角度是 angle,那么就容易算出武器的横坐标 x = Offset * sin(angle),同理,可算出武器的纵坐标 y = Offset * cos(angle)。按照这个原理,就可以实现武器按照角度分布,添加到武器根节点上。计算过程中,需要注意角度和弧度的转换,不同版本的 Cocos Creator 设置角度的 API 可能有差异,这个看官方文档就行。

fcabad539e78a8ceae108cbd58633e41.jpeg

五、选中未选中处理

这里,有添加一个额外处理,正常情况下,人物使用的纹理和选中使用的纹理,是有差异的,这个功能,主要是用在后期的游戏中的,目前只需要关注有这个功能即可。这个实现,也很简单,就是监听触摸事件,触摸开始更换一个纹理,触摸结束,再还原回来就行。

9acb9e8109066a48407cdac6c1eacbc2.gif

英雄有两种状态,进攻状态和防御状态,按下时是进攻,松开以后是防御状态。攻击状态下,武器会扩大攻击范围,武器有一定的倾斜度。防御状态下,武器笔直向外,离英雄更近。只需要单独的做每个武器做动画,修改武器的位置和偏移角度,计算方法类似上面的添加武器。

three 3

触摸滑动,控制人物的运动方向,以及游戏过程中,人物运动区域的控制

927eb2dccf353314798b7e8c6dac2fcb.gif

一、具体内容

人物通过滑动控制运动方向,即是往哪个方向滑动,人物就往哪个方向移动。人物只限定在下图蓝色边界内运动。

499639920a43b680da8f2dbb5abdd886.jpeg

二、边界的实现

游戏运动区域使用一张背景图,精灵修改成 TILED 模式,根据需要,可以修改背景的大小,改变整个游戏的区域,边界使用一张边界纹理,同样使用 TILED 模式,进行翻转、修改大小、调整位置,以达到上述界面效果。

21a03133455c2ccbb9ad050515203b9e.png

所有玩家的人物,都放到背景下的一个铺满父节点的根节点上。之所以没有直接放到背景节点上,是为了便于管理所有玩家的人物角色。

e69e93aecff7e486d93b8de41a09ddbe.jpeg

人物上下左右边界的最大最小值,可以在界面上拖动人物,获取最佳可见的位置信息,在脚本内,记录下来,后面控制人物运动时,作为临界值使用。

三、触摸时间监听

游戏过程中,人物是在游戏区域内,全图可以运动的,所以事件的监听,需要放到大地图上,如本案例,就可以挂在到背景图或人物根节点上,我选择的是挂载到背景节点上。

4381c8f903bcc3cb5cab4345805fe7e2.jpeg

需要监听 TOUCH_START、TOUCH_MOVE、TOUCH_END、TOUCH_CANCEL 四个事件,考虑到移动过程中,移动幅度的大小会影响游戏体验,我这里控制了一个变化值,当上一次到下一次的变化值超过 5 时,才按照偏移量计算运动的方向。

69a6d6df1d531dc9b0f2eee324747c78.jpeg

如上图,会保留一个变量存储上一次的位置,当移动的偏移量达到预设值 5 时,修改人物的运动方向,更新下一次的起始变量。人物的运动方向,计算变化的向量和 (0,1) 向量的夹角即可。

5d9a4fcdaa4cc61575ab18da7ebed701.jpeg

使用 Vec2 的 signAngle 能很方便的计算出两个向量的角度(弧度),人物的运动方向,就是根据这个弧度进行控制。

四、运动方向控制

游戏过程中,手指按下屏幕,人物处于进攻状态,松开手指,人物处于防守状态,防守状态下的人物,是不能移动的。在计算人物移动位置时,就需要人物在进攻状态下,才可以生效。下图左边是防守状态,右边是进攻状态。

599a8718334cf1dcd06ec87d5e111524.png

67f50d841b45e4572285749375e12a4e.png

位置的计算,也是根据上一步中设置的变化角度,计算下一步的运动位置,在人物的 update 函数内,动态更新人物的下一个位置。假设变化的偏移量是 offset,变化的角度是 angle(弧度表示),节点当前的位置是(x,y),下一步的位置(next_x,next_y)计算就是:

next_x = x + offset * sin(angle);

next_y = y + offset * cos(angle);

712cca98f00fd4342474702dd4ca2975.png

再判断 next_x 和 next_y 的合法性,如果验证通过,人物的下一个位置就是(next_x, next_y)。

2c378ba96e95b729cfb65b8299a0c877.png

五、边界的控制

上一步中,计算完人物的下个位置,需要判断是否超过上下左右的边界,在超过时,调整位置,最后直接更新人物位置即可。

92bc114afa40a441ffde8c5b6ed48e7d.png

游戏一开始,根据配置,加载多个人物到人物的根节点上,记录下玩家自己的节点,人物的运动逻辑,按照上述步骤控制,就可以实现屏幕中多个人物同时游戏的效果。

以上就是本次的分享,

如有问题或新的想法欢迎留言嗷~

更多笔记和源码欢迎关注作者的个人公众号哦~

 bf7919dad4a529dcb50534abddf16d84.gif

如果您在使用 Cocos Creator 2D/3D 的过程中

 get 了独到的开发心得、见解或是方法

欢迎分享出来

帮助更多开发者们解决技术问题

让游戏开发更简单~

期待您与我们联系~

21482963911a2288112629b663463fc7.gif

更多精彩

398853abdf4f3f194207e0627ea1de75.gif

Cocos 荣获金茶奖 2019 最佳游戏服务企业

Cocos Creator | 自由/约束的绳索效果

Cocos Creator 通用框架设计——资源管理

Cocos Creator v2.2.2 正式发布

来啊,斗图啊!Cocos 官方定制表情包来啦~

  - end -  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值