导语:这是一篇新手教程,适用于已看完Cocos官方文档,但还对游戏设计、运行流程不熟悉的新人。这篇教程是对文档【快速上手】里那款名叫"摘星星"的坑爹小游戏(文档原话)流程的梳理,以期望见微知著,得到游戏设计的一些普适性的方法,为看完文档仍然迷迷糊糊的新人提供一个游戏制作、运行的大体方向。

一、游戏元素

1、图片资源

·背景图 background

·开始按钮 btn_play

·主角 PurpleMonster

·地面 ground

·星星 star

2、场景

·Game

3、脚本

·Game.js

·Player.js

·Star.js

4、字体及声音

·jump

·score

·mikado_outline_shadow

5、预制资源

·Star

二、游戏场景

场景Game:

    官方:在 Cocos Creator 中,游戏场景(Scene)是开发时组织游戏内容的中心,也是呈现给玩家所有游戏内容的载体。游戏场景中一般会包括以下内容:

        ·场景图像和文字(Sprite,Label)

·角色

·以组件形式附加在场景节点上的游戏逻辑脚本

当玩家运行游戏时,就会载入游戏场景,游戏场景加载后就会自动运行所包含组件的游戏脚本,实现各种各样开发者设置的逻辑功能。所以除了资源以外,游戏场景是一切内容创作的基础。

    1、渲染根节点——Canvas

可以理解为一块要展示的黑板,后续需要添加的各种资源都会在这块"黑板"上。

2、背景图——background

在这款游戏中,可以理解为整个游戏的背景。

3、地面——ground

地面覆盖了一部分背景图,也算是整个游戏静态背景的一部分。

4、角色——Player

5、分数——Score

6、层级渲染关系

显示在下方的节点的渲染顺序是在上方节点的后面,也就是说下方的节点是在上方节点之后绘制的。

三、脚本

1、游戏逻辑脚本——Game.js

Game.js的内容可分为四部分,分别是属性、onload函数、update函数与其他函数。

·属性

a. star预制资源

b. star消失时间范围

c. 地面节点

d. Play节点

e. Label分数节点

f.得分音效

·onLoad函数

            onLoad方法会在场景加载后立刻执行,初始化相关的操作和逻辑都放在这里面。

            a. 得到地面坐标

            b. 初始化计时器

c. 生成新的星星

d. 初始化计分

·update函数

            update在场景加载后就会每帧调用一次,一般把需要经常计算或及时更新的逻辑内容放在这里。

a. 计时器更新

b. 超时判断

·其他函数

            a. 生成星星

b. 生成星星的随机位置

c. 得分

d. 游戏结束

2、Player节点脚本——Player.js

这个脚本绑定的是场景元素Player,也包含属性、onload函数、update函数与其他函数。

·属性

            a. 跳跃高度

            b. 跳跃持续时间

            c. 移速

            d. 加速度

            e. 音效资源

·onload函数

            a. 执行跳跃

            b. 监听初始化

            c. 加速度

d. 水平速度

·update函数

            a. 速度更新

            b. 速度限制

            c. 位置更新

·其他函数

            a. 跳跃

            b. 输入控制

            c. 播放声音

3、Star节点脚本——Star.js

star.js为Star预制资源的脚本。Star预制资源为脚本Game.js属性Star的引用。

·属性

            a. 星星与player的距离

            b. Game对象引用

        ·onLoad

            a. 根据属性a判断位置

            b. 星星的生成与销毁

            c. 调用得分方法

        ·update

            a. 判断距离

            b. 星星透明度的变化

四、小游戏分析

1、白话文版本

在一个背景图中有一个会不断跳跃的小妖怪,并且场景里会随机生成一个星星。当小妖怪把星星吃掉时,星星消失,得分加一,并生成新的星星,星星消失时仍然没有被吃掉,小妖怪GG,游戏结束。

2、正式版本

绑定到根节点的Game.js脚本负责游戏主逻辑,它负责生成背景图(background&ground)等各种资源(见Game.js属性),以及不同资源的调配(见Game.js函数)。场景中有一只会不断跳跃(Player.js)的小妖怪(Player)供玩家操作。场景随机产生(脚本中动态生成)一个星星(见star.js函数b)。当玩家按下键盘上的键时,触发Player节点的输入控制函数(Player.js.其他函数.b),对输入进行筛选,并更改加速度及方向的属性。当星星与Player的距离小于属性规定的距离时,星星消失,加一分,再生成新的星星。当星星超时消失,游戏结束。

3、图示

五、游戏设计流程的梳理

在这个游戏中,我们可以看到这款游戏得以运行的三要素(资源、脚本、场景)。其中资源和场景负责游戏的视觉、图像效果,而脚本则是串联各资源,既可以是单个元素的脚本(Player.js),也可以是整个游戏流程、规则的脚本(Game.js)。

除了上述提到 的游戏运行需要的条件,一个游戏的推出还需要其他要素的支持,如激励、剧情、交互等。

六、改进与进阶

1、在原游戏模式上的改进

·对触屏事件的处理。(cc.Node.EventType.TOUCH_START等)

·加入菜单模块,添加重新开始、暂停、退出等功能。

·加入手游摇杆(见附录)。

·加入边界,限制Player移到屏幕外。

2、略微改变游戏模式的案例——贪吃蛇

·星星改为食物,该模块可直接复制。

·加入手游摇杆,控制蛇身移动。

·重新定义蛇身类。

·基于案例小游戏的贪吃蛇正在酝酿之中,挖坑后填。

附录:

    手游摇杆系列

            ·四方向摇杆

            ·八方向摇杆

            ·跟随式摇杆

Cocos文档案例游戏设计的梳理与分析的更多相关文章

  1. 【Stage3D学习笔记续】山寨Starling(十):高效游戏设计、纹理集和ATF

    我发布了经过批处理优化的v0.3版,点击下载:https://github.com/hammerc/hammerc-study-Stage3D/archive/v0.3.zip 先看看我们批处理优化后 ...

  2. Unity游戏设计与实现 南梦宫一线程序员的开发实例

    图灵程序设计丛书 Unity游戏设计与实现:南梦宫一线程序员的开发实例(修订版)     加藤政树 (作者) 罗水东 (译者)  c# 游戏 unity   <内容提要>本书的作者是日本知 ...

  3. Robot Framework测试框架用例脚本设计方法

    Robot Framework介绍 Robot Framework是一个通用的关键字驱动自动化测试框架.测试用例以HTML,纯文本或TSV(制表符分隔的一系列值)文件存储.通过测试库中实现的关键字驱动 ...

  4. [libGDX游戏开发教程]使用libGDX进行游戏开发(1)-游戏设计

    声明:<使用Libgdx进行游戏开发>是一个系列,文章的原文是<Learning Libgdx Game Development>,大家请周知.后续的文章连接在这里 使用Lib ...

  5. Silverlight游戏设计(Game Design):(十四)练习用游戏素材资源的获取及相关工具使用心得 --转

    Silverlight游戏设计(Game Design):(十四)练习用游戏素材资源的获取及相关工具使用心得 通过前6节的Demo制作演示,大家应该已经相当熟悉这款Silverlight-2D游戏场景 ...

  6. 游戏设计艺术 第2版 (Jesse Schell 著)

    第1章 太初之时,有设计师 (已看) 第2章 设计师创造体验 第3章 体验发生于场景 第4章 体验从游戏中诞生 第5章 游戏由元素构成 第6章 元素支撑起主题 第7章 游戏始于一个创意 第8章 游戏通 ...

  7. MMORPG大型游戏设计与开发(服务器 AI 概述)

    游戏世界中我们拥有许多对象,常见的就是角色自身以及怪物和NPC,我们可以见到怪物和NPC拥有许多的行为,比如说怪物常常见到敌对的玩家就会攻击一样,又如一些NPC来游戏世界中走来走去,又有些怪物和NPC ...

  8. MMORPG大型游戏设计与开发(客户端架构 part8 of vegine)

    脚本模块是游戏设计中争论比较多的话题,那是因为作为脚本本身所带来的利弊.其实这都无关紧要,取舍是人必须学会的一项技能,如果你不会取舍那么就让趋势给你一个满意的答复.自从魔兽世界以及传奇(世界)问世以来 ...

  9. MMORPG大型游戏设计与开发(概述)updated

    1.定义 MMORPG,是英文Massive(或Massively)Multiplayer Online Role-PlayingGame的缩写,即大型多人在线角色扮演游戏. 2.技术与知识 在这系列 ...

随机推荐

  1. DataTables使用总结

    一.使用方法     1.引入JS文件 <script src="js/plugin/datatables/jquery.dataTables.min.js">< ...

  2. [mvc]记一次“项目”的历程

    大二上半学期因为选修课的原因,答应帮老师完善学院的选课系统.在这之前没有做过一个可以成为“项目”的项目,本着挑战自己的原则和可以不上选修课的福利,断断续续用了一学期的时间来完善这个选课系统. 接受这个 ...

  3. AGC007C Pushing Balls

    题目链接 题意:\(N\)个坑,\(N+1\)个球,相间分布,距离为以\(d_1\)为首项,\(x\)为公差的等差数列.对于每次操作,随机选择一个未入坑的球,随机选择向左或向右,掉入第一个没有球的坑, ...

  4. 【12c OCP】最新CUUG OCP-071考试题库(49题)

    49.(11-1) choose the best answer Examine the structure of the SHIPMENTS table: You want to generate ...

  5. 微信小程序转发商品的详情页 + 转发功能(传参)

    1.微信小程序转发传参,利用的还是onShareAppMessageapi 2.利用的还有json转换 JSON 是用于存储和传输数据的格式. JSON 通常用于服务端向网页传递数据 函数 描述JSO ...

  6. php 递归数据,三维数组转换二维

    public function sortarea($area, $parent_id = 0, $lev = 1){ static $list; foreach($area as $v){ if($v ...

  7. jquery源码解析:jQuery数据缓存机制详解2

    上一课主要讲了jQuery中的缓存机制Data构造方法的源码解析,这一课主要讲jQuery是如何利用Data对象实现有关缓存机制的静态方法和实例方法的.我们接下来,来看这几个静态方法和实例方法的源码解 ...

  8. GPS坐标转百度地图坐标

    百度地图提供了相关API:BMap.Convertor.translate, 但是使用上存在部分限制:1.次数限制:2.异步回调 可以用如下方法: /** * 地图位置计算工具(将GPS坐标转换成百度 ...

  9. P4915 帕秋莉的魔导书

    题目链接 题意分析 当前等级为\(x\)的魔法书会对等级在\([x,inf]\)的所有人造成\(y\)的影响 所以除了求平均值之外 就是区间修改区间求和 需要使用动态开点 + 标记永久化 需要注意的是 ...

  10. Word2Vec原理及代码

    一.Word2Vec简介 Word2Vec 是 Google 于 2013 年开源推出的一款将词表征为实数值向量的高效工具,采用的模型有CBOW(Continuous Bag-Of-Words,连续的 ...