Cocos2d开发系列(一)
最后更新于:2022-04-01 11:38:52
Cocos2d是一个比较流行的iphone游戏开发框架,据说在AppStore 上已有超过 100 个游戏是基亍 Cocos2D-iPhone。其中 3 个由此 迚入过 TOP 10 的排名。其中的 StickWars 更是曾排名第一。现在,让我们来开始Cocos2d的学习之旅吧!
## 一、安装下载
Cocos2d下载地址:[http://code.google.com/p/cocos2d-iphone/downloads/list](http://code.google.com/p/cocos2d-iphone/downloads/list)
当前最新版本为1.0。本教程选用的是稳定版本0.99.5。
下载文件为targ.gz格式,将其解压到某个目录下,打开该目录,找到install-templates.sh文件,这个就是Cocos2d的安装脚本。
你可以直接在终端里运行这个脚本进行安装,但如果你的Xcode没有安装在默认目录下,则你需要在命令中添加一个参数。
例如,你的Mac中可能同时存在一个Xcode版本(3.2.5),安装目录为:/Users/$yourname$/Developer,如果你想将Cocos2d安装到这个Xcode(3.2.5),则需要使用用命令:
~~~
./install-templates.sh /Users/$yourname$/Developer
~~~
来进行安装。
安装完毕,你可以打开Xcode,新建Project,你会在UserTemplates目录下看到多了4个Cocos2d Application模板(如果是0.99版本,则只有3个模板):
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-05-04_572a0b8ff2882.gif)
## 二、新建cocos2dApplications项目
新建一个cocos2dApplications项目,编译运行效果如下:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-05-04_572a0b9195d9b.gif)
打开HelloWorldScene.h,可以看到如下代码:
~~~
#import "cocos2d.h"
// HelloWorld Layer
@interface HelloWorld : CCLayer
{
}
// returns a Scenethat contains the HelloWorld as the only child
+(id) scene;
@end
~~~
首先,import指令导入了cocos2d.h,在这个.h文件中,已经包含(import)了cocos2d的所有类。因此我们导入了cocos2d.h后,就不需要再一个个导入要用到的cocos2d类了。
其次,HelloWorldScene.h中定义了一个CCLayer子类。CCLayer即所谓“层”的概念。层是一个容器的概念,cocos2d在层上放置多个动画元素,如文字、标签、图片、菜单,此外层接收触摸和加速器事件。
第三,定义了一个静态方法,返回了一个——Scene,这个Scene实际上包含了一个层——HelloWorld,这是一个不错的实例化方法。Coco2d中Scene的概念,类似于电影中“场景”的概念--由于受舞台空间或屏幕空间的限制,一个情节往往只能在固定的空间环境中展现,而电影往往是由许多个情节构成, 随着剧情的发展,场景也需要改变,新的场景需要产生。所以电影就会在一幕幕场景中进行切换 ,这种切换被称为“转场”。
切换到HelloWorldScene.m :
~~~
#import "HelloWorldScene.h"
// HelloWorldimplementation
@implementation HelloWorld
~~~
上面导入了HelloWorldScene.h并实现了HelloWorld类。O-C中,文件名不见得需要和类名一致。
~~~
+(id) scene
{
……
}
~~~
这个方法就不介绍了,和前面说过的一样。
~~~
-(id) init
{
if( (self=[superinit] )) {
CCLabelTTF *label = [CCLabelTTFlabelWithString:@"HelloWorld"fontName:@"MarkerFelt"fontSize:64];
CGSize size = [[CCDirectorsharedDirector] winSize];
label.position = ccp(size.width /2 , size.height/2 );
[selfaddChild: label];
}
returnself;
}
~~~
init方法中,创建了一个标签 CCLabelTTF (以前是CCLabel)并让他居中。ccp函数是CGPointMake函数的缩写。
接下来,看一下应用程序委托,如果你有过Cocoa编程的经验,那么会发现这就是一个UIApplicationDelegate,它的主要方法是applicationDidFinishLaunching:(UIApplication*)application :。
,并将EAGLView绑定到
首先取得Director——导演。导演是cocos2d程序的统筹者和协调者,负责整个应用程序的主窗口的创建,以及每个场景在时间线上的先后顺序。
~~~
CCDirector *director = [CCDirectorsharedDirector];
~~~
然后创建EAGLView实例。EAGLView 派生亍类 UIView, 苹果公司用它来实现 OpenGL 输出支持,以支持OpenGLES 编程:
~~~
EAGLView *glView = [EAGLView viewWithFrame:[windowbounds]
pixelFormat:kEAGLColorFormatRGB565
depthFormat:0
];
~~~
并将EAGLView绑定到导演的openGLView属性:
~~~
[director setOpenGLView:glView];
~~~
设置横屏:
~~~
setDeviceOrientation:kCCDeviceOrientationLandscapeLeft];
~~~
设置帧间隔(尚未实现):
~~~
[director setAnimationInterval:1.0/60];
~~~
设置帧率显示,即屏幕左下角不断变化的数字:
~~~
[director setDisplayFPS:YES];
~~~
设置渲染格式位32位RGB:
~~~
[CCTexture2DsetDefaultAlphaPixelFormat:kCCTexture2DPixelFormat_RGBA8888];
~~~
移除闪屏,即一开始的那个coco2d Logo标志的屏幕:
~~~
[selfremoveStartupFlicker];
~~~
显示HelloWorld文字标签的场景:
~~~
[[CCDirectorsharedDirector] runWithScene: [HelloWorldscene]];
}
~~~