cocos2d-x3.2中的基础概念

在你阅读本章节之前你可能知道一些关于Cocos2d-x的知识,但是你可能想知道更多关于如何使用Cocos2d-x来制作出自己梦想的游戏。

没问题,让我们从现在开始。

Cocos2d-x是一个跨平台的游戏引擎。什么是游戏引擎?现在不要被这个问题吓到!

一个游戏引擎就是一个可以提供大多游戏常用功能的软件作品。你之前也许听到过将它称之为API或者框架。但在本书中我们会使用游戏引擎这个比较正式的术语。

游戏引擎包括了许多组件,将它们组合使用有利于游戏性能提升和开发周期的缩短。

通常游戏引擎中都包含这些组件,比如:渲染器,2d/3d图形,碰撞检测,物理引擎,声音,控制器,动画等。

游戏引擎通常支持多平台,所以会比较容易对游戏进行移植,将游戏移部署到其它平台只需要一小部分的工作量。

由于Cocos2d-x是一个游戏引擎,它提供了一个简化的API用来开发跨平台的移动和桌面游戏。

通过内置的封装且易于使用的API,你可以专注于开发游戏,不用去关心内部技术的实现。

Cocos2d-x将会尽可能的为游戏开发者提供更大的自由空间。

Cocos2d-x提供了Scene,Transition,Sprite,Menu,Sprite3D,Audio等许多对象。你创建游戏所需要的内容都在这了。

主要组件

看起来好像很复杂,但是开始使用Cocos2d-x是很简单的。

在我们继续进行深入之前,需要理解一些Cocos2d-x中的概念。

Cocos2d-x的核心类为Scene,Node,MenuAction对象。仔细观察你玩过的游戏你就会发现所有这些部分!

让我们来看一个例子。这看起来像一个很流行的游戏,你也许玩过:

\p1\

你能找出这些部分吗?让我们来分析一下:

\p2\

也许你对自己的游戏有一个大概的描绘?和上面的例子对比一下你的游戏中都包括了哪部分。

导演类

Cocos2d-x使用Director(导演)的概念。是的,就像拍电影一样!

Director类控制着游戏整体并通知游戏接下来需要做什么。

把你自己当成影片的监制人,你肯定会通知导演(Director)该如何做!

Director导演的一个通常作用是控制Scene切换和切换效果。

导演(Director)是一个共享的单例对象,你可以从代码的任何地方调用。

这里是一个典型游戏的流程图。导演 (Director)通过这个流程图来对游戏进行调渡并决定了游戏的标准:

\p3\

你就是游戏的导演。你决定了游戏中将会发生什么,什么时候发生,如何发生。

这些你都要负责!

场景

游戏中你可能需要一个主菜单,几个关卡和一个结束场景。

你该如何将这些内容单独的分开来呢?是的,这就需要Scene

回想一下你喜欢的电影,你会发现它很显示的划分出了一些场景,或者单独的故事剧情。

如果我们按照这种思路来处理游戏,不管游戏有多么简单但我们应该想出至少有几个场景。

看下这张图片:

\p4\

这是一个独立的主界面场景Scene。这个场景是将组件组合在一起而形成一个最终的场景。

场景都由Renderer进行绘制。Renderer可以用来绘制精灵或者其它对象到场景中。为了更好的理解这点我们需要了解一些关于_Scene Graph_的知识。

场景图

_scene graph_是一个用来存储场景图形的数据结构。

_scene graph_由树节点构成。(它虽然叫screne graph,但它实际上是用树形结构来存储)。

\p5\

这看起来好像很复杂。我敢肯定你会问为什么我们要了解这些底层技术,这不是和cocos2d-x的原则相违背吗?实际上,明白场景是如何来进行绘制的这一点恨得很有必要。当你在游戏中添加节点,精灵或者动画的时候,你肯定希望最终的表现结果是你所预期的。但如果没有达到预期效果呢?

如果你添加的精灵对象在背景层但你希望它们在最前面该怎么办?回到上一步通过将场景放到一个背景上然后在运行,我敢保证你很快会发现自己所犯的错误。

由于_Scene Graph_是树形结构;你可以对它进行遍历。Cocos2d-x使用了_in-order walk_算法。_in-order walk算法的流程如图所示,从根节点开始,然后到右边的树。由于右边的节点是最后绘制的,所以它会首先被显示到场景中。

\p6\

_scene graph_很容易理解,让我们来对图中所示的场景进行分解:

\p7\

将上面的场景表示为一个树形,可以简化为如下:

\p8\

另一个需要注意的地方是,_z-order_Z轴为负数的元素会出现在树的左侧,而_z-order_Z轴为正数的会出现在树的右侧。

当在场景中添加结点的时候需要注意这一点。当然你可以在任意的地方添加节点元素它们会被按钮Z轴的大小自动排序。

在这个概念的基础上,我们可以把Scene的视为一个Node对象。

先暂时不看上一个场景,来看一下_scene graph_如何利用_z轴_来布局Scene

\p9\

图中左边的场景是由许多节点对象组成的,但每个对象都处在不同的_z-order_Z轴上。

在Cocos2d-x中,可以通过API中的addChild()方法来创建_scene graph_场景。

1

2

3

4

5

6

7

8

9

10

// Adds a child with the z-order of -2,that means

// it goes to the "left" side of the tree (because it is negative)

scene->addChild(title_node,-2);

// When you don't specify the z-order,it will use 0

scene->addChild(label_node);

// Adds a child with the z-order of 1,that means

// it goes to the "right" side of the tree (because it is positive)

scene->addChild(sprite_node,1);

精灵

所有的游戏都有_Sprites_精灵,你可能知道或者不知道它们是什么。精灵就是游戏中在场景里进行移动的对象。

你可以操纵它们。精灵可能是游戏中最主要的角色。我知道你在想什么-难道每一个图形对象都是精灵Sprite吗?

当然不是!为什么?当你操纵一个精灵的时候,它就是一个精灵。如果你不对它进行操作,那它就是一个节点Node

看一下图片,我们来说明一下什么是精灵,什么是节点:

\p10\

精灵是每一个游戏的关键所在。编写一个游戏,你可能需要使用一些带有共同特性的图像。这就是一个Sprite精灵。

_Sprites_精灵很容易创建,它具有很多属性,比如:坐标position,翻转rotation,缩放scale,透明度opacity,颜色color等。

1

2

3

4

5

6

7

8

9

10

11

// This is how to create an sprite

auto mySprite = Sprite::create("mysprite.png");

// this is how to change the properties of the sprite

mySprite->setPosition(Vec2(500,0));

mySprite->setRotation(40);

mySprite->setScale(2.0); // sets scale X and Y uniformly

mySprite->setAchorVec2(0,0);

下面我们来解释每个属性的作用,通过本章的示例代码来思考下面的截图:

\p11\

通过代码mySprite->setPosition(Vec2(500,0));将坐标进行重新设置,如图:

\p12\

看一下发生了什么。Sprite的坐标从它原有的坐标被移动到了我们设定的新坐标。

通过代码mySprite->setRotation(40);对精灵的翻转进行设定,如图:

\p13\

看一下发生了什么。Sprite精灵被翻转了我们所设定的角度。

通过代码mySprite->setScale(2.0);将精灵进行缩放,如图:

\p14\

同样地,我们可以发现精灵的大小被改变了。

最后,所有的节点Node对象(注意Sprite精灵类是Node节点类的子类)都有一个称为锚点的值。我们之前还没有提过这个概念,现在时机正好。你可以将锚点想象为在对精灵进行坐标点设定的时候精灵所自身使用的坐标点。

通过代码mySprite->setAchorVec2(0,0);将游戏中的精灵锚点设定为(0,0)坐标,那么所有使用代码setPosition()进行坐标设定的精灵都会以自身的左下角来进行对齐。让我们来试一下:

\p15\

\p16\

\p17\

\p18\

\p19\

注意观察每个图像中的红点。这个红点就是精灵的锚点位置!

你会发现锚点对节点来说是非常有用的。你甚至可以通过调整精灵的锚点来模拟动态效果。

现在我们已经可以很好地使用精灵了。那么该如何让这些精灵按照一定的时间间隔自动的进行播放呢?继续向下看。

动作

创建Scene场景,添加Sprite精灵对象到屏幕上只是其中一部分。

游戏之所以称为游戏就是我们需要让精灵运动起来!Action动作游戏中的一部分。_Actions_动作类可以让Node节点对象按时间进行运动。

希望将一个Sprite精灵从一个坐标点移动到另一个坐标并在结束时调用回调函数?没有问题!

你可以创建一个Actions动作序列Sequence并且按顺序播放。你可以通过改变Node节点属,坐标,角度,缩放。比如说这些动作:MoveByRotate,Scale。所有的游戏都使用动作类Actions

查看本章的示例代码,下面就是_Actions_的演示:

\p20\

5秒过后,精灵会移动到新的坐标点:

\p21\

_Actions_很容易创建使用:

1

2

3

4

5

6

7

8

9

auto mySprite = Sprite::create("Blue_Front1.png");

// Move a sprite 50 pixels to the right,and 10 pixels to the top over 2 seconds.

auto moveBy = MoveBy::create(2,Vec2(50,10));

mySprite->runAction(moveBy);

// Move a sprite to a specific location over 2 seconds.

auto moveTo = MoveTo::create(2,10));

mySprite->runAction(moveTo);

序列和Spawns

让精灵在屏幕中进行移动就是我们想要的最终结果了吗?当然不是。可不可以运行多个动作呢?是的,没问题,Cocos2d-x通过几个方式来支持这种操作。

就如同它的名字,一个序列Sequence就是多个动作按钮一定顺序进行排列。需要按反方向来播放序列动作?也没问题,Cocos2d-x也支持这个操作。

看一下面的例子,通过序列Sequence逐步移动一个精灵Sprite:

\p22\

这个Sequence很容易创建:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

auto mySprite = Node::create()

// move to point 50,10 over 2 seconds

auto moveTo1 = MoveTo::create(2,10));

// move from current postion by 100,10 over 2 seconds

auto moveBy1 = MoveBy::create(2,Vec2(100,10));

// move to point 150,10 over 2 seconds

auto moveTo2 = MoveTo::create(2,Vec2(150,10));

// create a delay

auto delay = DelayTime::create(1);

mySprite->runAction(Sequence::create(moveTo1,delay,moveBy1,delay->clone(),moveTo2,nullptr));

本例中按顺序播放序列中的每一个动作,如何同步一起运行这些动作?Cocos2d-x也支持这个操作,它称做SpawnSpawn会在同一时间播放所有指定的动作。有一些可能比别的稍长一些,所以出现这种情况动作的播放不会在同一时间完成。

1

2

3

4

5

6

7

auto myNode = Node::create()

auto moveTo1 = MoveTo::create(2,10));

auto moveBy1 = MoveTo::create(2,10));

auto moveTo2 = MoveTo::create(2,10));

myNode->runAction(Spawn::create(moveTo1,nullptr));

为什么要使用Spawn呢?有什么理由吗?当然!当游戏的主角获得能力提升时要播放多个动作的时候。当BOSS战的最后阶段需要同时播放多个动作来终结的时候。

父类和子类之间的继承关系

Cocos2d-x使用Parent and Child继承。也就是说父类中的属性也适用于他们的子类。考虑一个Sprite对象和它的子类对象Sprite

\p23\

当改变父类中的精灵角度时,子类的角度也会随之进行变化:

\p24\

1

2

3

4

auto myNode = Node::create();

// rotating by setting

myNode->setRotation(50);

不光是角度,如果你将父类进行缩放,那么子类的精灵也会跟着缩放:

\p25\

1

2

3

4

auto myNode = Node::create();

// scaling by setting

myNode->setScale(2.0); // scales uniformly by 2.0

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


    本文实践自 RayWenderlich、Ali Hafizji 的文章《How To Create Dynamic Textures with CCRenderTexture in Cocos2D 2.X》,文中使用Cocos2D,我在这里使用Cocos2D-x 2.1.4进行学习和移植。在这篇文章,将会学习到如何创建实时纹理、如何用Gimp创建无缝拼接纹
Cocos-code-ide使用入门学习地点:杭州滨江邮箱:appdevzw@163.com微信公众号:HopToad 欢迎转载,转载标注出处:http://blog.csdn.netotbaron/article/details/424343991.  软件准备 下载地址:http://cn.cocos2d-x.org/download 2.  简介2.1         引用C
第一次開始用手游引擎挺激动!!!进入正题。下载资源1:从Cocos2D-x官网上下载,进入网页http://www.cocos2d-x.org/download,点击Cocos2d-x以下的Download  v3.0,保存到自定义的文件夹2:从python官网上下载。进入网页https://www.python.org/downloads/,我当前下载的是3.4.0(当前最新
    Cocos2d-x是一款强大的基于OpenGLES的跨平台游戏开发引擎,易学易用,支持多种智能移动平台。官网地址:http://cocos2d-x.org/当前版本:2.0    有很多的学习资料,在这里我只做为自己的笔记记录下来,错误之处还请指出。在VisualStudio2008平台的编译:1.下载当前稳
1.  来源 QuickV3sample项目中的2048样例游戏,以及最近《最强大脑》娱乐节目。将2048改造成一款挑战玩家对数字记忆的小游戏。邮箱:appdevzw@163.com微信公众号:HopToadAPK下载地址:http://download.csdn.net/detailotbaron/8446223源码下载地址:http://download.csdn.net/
   Cocos2d-x3.x已经支持使用CMake来进行构建了,这里尝试以QtCreatorIDE来进行CMake构建。Cocos2d-x3.X地址:https://github.com/cocos2d/cocos2d-x1.打开QtCreator,菜单栏→"打开文件或项目...",打开cocos2d-x目录下的CMakeLists.txt文件;2.弹出CMake向导,如下图所示:设置
 下载地址:链接:https://pan.baidu.com/s/1IkQsMU6NoERAAQLcCUMcXQ提取码:p1pb下载完成后,解压进入build目录使用vs2013打开工程设置平台工具集,打开设置界面设置: 点击开始编译等待编译结束编译成功在build文件下会出现一个新文件夹Debug.win32,里面就是编译
分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!http://www.captainbed.net前言上次用象棋演示了cocos2dx的基本用法,但是对cocos2dx并没有作深入的讨论,这次以超级马里奥的源代码为线索,我们一起来学习超级马里奥的实
1. 圆形音量button事实上作者的本意应该是叫做“电位计button”。可是我觉得它和我们的圆形音量button非常像,所以就这么叫它吧~先看效果:好了,不多解释,本篇到此为止。(旁白: 噗。就这样结束了?)啊才怪~我们来看看代码:[cpp] viewplaincopyprint?CCContro
原文链接:http://www.cnblogs.com/physwf/archive/2013/04/26/3043912.html为了进一步深入学习贯彻Cocos2d,我们将自己写一个场景类,但我们不会走的太远,凡是都要循序渐进,哪怕只前进一点点,那也至少是前进了,总比贪多嚼不烂一头雾水的好。在上一节中我们建
2019独角兽企业重金招聘Python工程师标准>>>cocos2d2.0之后加入了一种九宫格的实现,主要作用是用来拉伸图片,这样的好处在于保留图片四个角不变形的同时,对图片中间部分进行拉伸,来满足一些控件的自适应(PS: 比如包括按钮,对话框,最直观的形象就是ios里的短信气泡了),这就要求图
原文链接:http://www.cnblogs.com/linji/p/3599478.html1.环境和工具准备Win7VS2010/2012,至于2008v2版本之后似乎就不支持了。 2.安装pythonv.2.0版本之前是用vs模板创建工程的,到vs2.2之后就改用python创建了。到python官网下载版本2.7.5的,然后
环境:ubuntu14.04adt-bundle-linux-x86_64android-ndk-r9d-linux-x86_64cocos2d-x-3.0正式版apache-ant1.9.3python2.7(ubuntu自带)加入环境变量exportANDROID_SDK_ROOT=/home/yangming/adt-bundle-linux/sdkexportPATH=${PATH}:/$ANDROID_SDK_ROOTools/export
1开发背景游戏程序设计涉及了学科中的各个方面,鉴于目的在于学习与进步,本游戏《FlappyBird》采用了两个不同的开发方式来开发本款游戏,一类直接采用win32底层API来实现,另一类采用当前火热的cocos2d-x游戏引擎来开发本游戏。2需求分析2.1数据分析本项目要开发的是一款游
原文链接:http://www.cnblogs.com/linji/p/3599912.html//纯色色块控件(锚点默认左下角)CCLayerColor*ccc=CCLayerColor::create(ccc4(255,0,0,128),200,100);//渐变色块控件CCLayerGradient*ccc=CCLayerGradient::create(ccc4(255,0,0,
原文链接:http://www.cnblogs.com/linji/p/3599488.html//载入一张图片CCSprite*leftDoor=CCSprite::create("loading/door.png");leftDoor->setAnchorPoint(ccp(1,0.5));//设置锚点为右边中心点leftDoor->setPosition(ccp(240,160));/
为了答谢广大学员对智捷课堂以及关老师的支持,现购买51CTO学院关老师的Cocos2d-x课程之一可以送智捷课堂编写图书一本(专题可以送3本)。一、Cocos2d-x课程列表:1、Cocos2d-x入门与提高视频教程__Part22、Cocos2d-x数据持久化与网络通信__Part33、Cocos2d-x架构设计与性能优化内存优
Spawn让多个action同时执行。Spawn有多种不同的create方法,最终都调用了createWithTwoActions(FiniteTimeAction*action1,FiniteTimeAction*action2)方法。createWithTwoActions调用initWithTwoActions方法:对两个action变量初始化:_one=action1;_two=action2;如果两个a
需要环境:php,luajit.昨天在cygwin上安装php和luajit环境,这真特么是一个坑。建议不要用虚拟环境安装打包环境,否则可能会出现各种莫名问题。折腾了一下午,最终将环境转向linux。其中,luajit的安装脚本已经在quick-cocos2d-x-develop/bin/中,直接luajit_install.sh即可。我的lin
v3.0相对v2.2来说,最引人注意的。应该是对触摸层级的优化。和lambda回调函数的引入(嗯嗯,不枉我改了那么多类名。话说,每次cocos2dx大更新。总要改掉一堆类名函数名)。这些特性应该有不少人研究了,所以今天说点跟图片有关的东西。v3.0在载入图片方面也有了非常大改变,仅仅只是