导语:这是一篇新手教程,适用于已看完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、略微改变游戏模式的案例——贪吃蛇

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

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

·重新定义蛇身类。

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

附录:

    手游摇杆系列

            ·四方向摇杆

            ·八方向摇杆

            ·跟随式摇杆

转载于:https://www.cnblogs.com/magicxyx/p/9397622.html

Cocos文档案例游戏设计的梳理与分析相关推荐

  1. 游戏场景设计文档案例_产品经理、设计、运营入门与进阶(132本书籍+需求文档+案例)...

    本期"职场充电驿站"整理了一些产品经理.设计.运营入门与进阶相关的资源,包括132本设计了书籍.海量产品需求文档.产品案例.产品设计相关工具等. [产品经理.设计.运营入门与进阶] ...

  2. es修改索引java_Elasticsearch添加修改删除索引文档案例分享

    本文介绍如何采用bboss es添加/修改/删除/批量删除elasticsearch索引文档,直接看代码. 添加/修改文档 TAgentInfo agentInfo = new TAgentInfo( ...

  3. 游戏设计文档的功能及类型

    设计文档需要满足以下各个游戏制作部门和人员的要求: 1.编程人员必须可以理解游戏设计文档,并且可以根据他有效的起草游戏软件需求文档和软件技术设计文档 2.由艺术指导带领的艺术设计团队可以通过阅读游戏设 ...

  4. 美国计算机游戏设计专业排名,2018美国游戏设计留学院校排名

    原标题:2018美国游戏设计留学院校排名 美国的游戏设计专业在近几年深受艺术留学生的青睐,并且,国内很多游戏设计专业学生都选择申请美国的院校.那么,美国有哪些游戏设计专业院校呢?下面是美行思远小编整理 ...

  5. 【游戏设计系列】关于游戏设计文档

    如何编写设计文档 设计文档的分类 迷你型设计(mini design) 定义:一周左右完成的设计,一个完整却简单的游戏描述 要求 任何一团队成员能够摘录与阅读 读者能够了解游戏设计者的设计意图 读者能 ...

  6. java拼图游戏设计文档_基于JAVA的拼图游戏的设计与实现(含录像)

    基于JAVA的拼图游戏的设计与实现(含录像)(任务书,开题报告,中期检查表,外文翻译,毕业论文15500字,程序代码,答辩PPT,答辩视频录像) 摘  要 在我们日常生活中,有很多的益智类游戏,如七巧 ...

  7. 如何书写游戏设计文档

    内容来自书籍<通关!游戏设计之道>,本人只是节选了部分觉得有趣或者有意义的内容,感兴趣的可以去看一下原书. 下面是正文: --------------------------------- ...

  8. 复古像素风游戏设计之:需求文档

    复古像素风游戏设计之:需求文档 引言 在这个流行运用3D建模重现现实世界.使用大量精美贴图渲染视觉效果的游戏时代,或许大多数人会被那些震撼逼真的场景设定所吸引,而习惯性的对那些画面略显粗糙的游戏嗤之以 ...

  9. 通关!游戏设计之道的学习笔记(四)文档

    一款游戏,你得从游戏的设计文档开始做起.在游戏开放的筹备阶段,需要有以下4中文档来帮忙进行工作:①单页说明书②十页说明书③游戏流程表④游戏设计文档,简写为GDO. 单页说明书 包含以下信息: 1.游戏 ...

  10. 以《少年三国志2》为例,分析数值驱动的滚服游戏设计

    一.前言 1)游戏简介 <少年三国志2>由上海游族信息技术有限公司制作发行的一款三国题材的横版卡牌手游,该作于2020年3月27日正式公开测试. 玩家在游戏内扮演一名在时空局实习的少年,因 ...

最新文章

  1. Void void Void用在泛型
  2. scp时候出现ssh Connection refused的解决方案
  3. JavaScript产生一个n到m之间的随机数
  4. Java笔记(08):面向对象--抽象类
  5. 【Python web 开发】viewset 实现商品详情页的接口
  6. 面试官 | SpringBoot 中如何实现异步请求和异步调用?
  7. mysql1000w数据怎么加索引_给mysql一百万条数据的表添加索引
  8. 7-9 主从复制常见问题
  9. jquery------导入jquery.2.2.3.min.js
  10. 证件照制作(一寸二寸照片制作)微信小程序源码
  11. PLC编程实现堆栈功能
  12. 【CSS】设置 border 长度
  13. 使用自己的激光雷达在cartographer导航框架下绘制地图,报错 lua_parameter_dictionary.cc:83] Check failed: status == 0解决方法。
  14. 搜狗拼音输入发-自定义短语记录
  15. 2011黑帽大会:由黑客操控的世界
  16. 第八届蓝桥杯(国赛)——瓷砖样式
  17. 【Tableau Desktop 企业日常问题23】Tableau 筛选之后如何保持原有排序顺序?
  18. 什么是过拟合(overfitting)
  19. XXE漏洞介绍及利用
  20. upper_bound和lower_bound用法(史上最全)

热门文章

  1. 数字图像处理--梯度倒数加权平滑法
  2. malloc函数用法
  3. 仿某某网站模板thinkphp_7个免费PPT模板网站,远离撞P的尴尬
  4. 日期选择器_FPGA逻辑部分Verilog实验-选择器电路
  5. shell 提取sql 的字段名表名_Mysql常用SQL语句集锦 |建议转发收藏
  6. Hyperledger Fabric教程(12)-- 交易过程
  7. Kubernetes 小白学习笔记(14)--k8s集群路线-kubernetes核心组件详解
  8. thinkphp 按指定字段统计数据条数
  9. gtx1050ti最稳定的驱动_【硬件资讯】持续霸榜经久不衰?四岁高龄的GTX1060仍为Steam最受欢迎显卡!...
  10. python使用密钥加密的表述_Python生成rsa密钥对操作示例