zoukankan      html  css  js  c++  java
  • 如何在 Mac 上创建一个 cocos2d 的项目

    转载自:http://disanji.net/2010/11/20/howto-create-a-cocos2d-mac-project/

    我已经关注cocos2d小组一段时间了,他们最近的发布版本支持在Mac OS X系统上创建项目。也许是为即将上线的Mac App Store作准备,cocos2d团队正在努力使得从iPhone/iPad到Mac OS X上程序的移植更简单。

    目前似乎并不能100%地支持Mac OS X系统,但是基础功能可以实现。你或许比较关心如何使自己iPhone上的项目转而支持Mac OS X,实话说我没找到简单的方法,因此倘若有人可以站出来帮我的话,我非常感激。但是这篇教程的目的将是创建一个新的应用程序。

    下面让我们回顾一下为完成这个任务而需要的步骤。

    这里可以下载最新的cocos2d版本。完成下载之后,解压到Mac上的文件夹中。

    1. 创建新的Cocoa工程。
    2. 将Cocos2d资源添加到项目中
    3. 编辑AppDelegate.h 和AppDelegate.m文件
    4. 引入架构
    5. 创建新的Objective-C的类
    6. 为MainMenu.xib更改Interface Builder中的设置
    7. 引入样例文件

    我还得说这不一定是在OS X上创建使用Cocos2d的项目的最好的或唯一的方式,有一些步骤可能是多余的或者是不对的。下面只是我采取的步骤,如果你们有更好的建议来使这篇教程更完善,请放心的告诉我。

    创建新的Cocoa工程

    首先我们需要打开Xcode之后开始新的项目。然而这一次,我们将用在Mac OS X->Application下的Cocoa Application模板而不是预定义的cocos2d模板。下面是屏幕截图:

    一旦你创建了新的项目,你会看到Xcode界面出现。这篇教程中我的程序命名为Demo Mac Port。你的屏幕跟下面的截图看起来应该差不多。

    在下一步将要添加cocos2d资源到项目中,确定你已经下载了支持Mac OS X的最新的cocos2d的版本。

    将Cocos2d资源添加到项目中

    这一步你需要cocos2d文件,如果你还没有下载,那么你可以在这里下载最新版本。下载后解压到你的硬盘上。

    解压缩之后,打开cocos2d-iphone-0.99.5-beta3文件夹找到cocos2d文件夹。屏幕截图如下:

    这个文件夹需要添加到工程中。我通常把它直接从文件查找窗口拖拽到工程中。只需拖拽到在程序名下工程中,与下面截图类似的一个对话框就会出现:

    之后你的Xcode工程界面跟下面看起来相似:

    下一个环节将引导你修改AppDelegate.h 和AppDelegate.m文件。

    编辑AppDelegate.h 和AppDelegate.m文件

    这一部分你会修改这两个文件使它们与Cocos2d相兼容。我在这里不会解释代码但是详细的代码我粘贴在下面:

    AppDelegate.h

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    
    #import "cocos2d.h"
     
    @class CCSprite;
     
    //CLASS INTERFACE
    #ifdef __IPHONE_OS_VERSION_MAX_ALLOWED
    @interface AppController : NSObject
    {
    	UIWindow *window;
    }
    @end
     
    #elif defined(__MAC_OS_X_VERSION_MAX_ALLOWED)
    @interface Demo_Mac_PortAppDelegate : NSObject  {
        NSWindow *window_;
    	MacGLView *glView_;
    }
     
    @property (assign) IBOutlet NSWindow *window;
    @property (assign) IBOutlet MacGLView *glView;
     
    @end
    #endif // Mac

    AppDelegate.m

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    
    // 动作演示
    // a cocos2d example
    // http://www.cocos2d-iphone.org
    //
     
    //本地引入
    #import "cocos2d.h"
    #import "Demo_Mac_PortAppDelegate.h"
    #import "DemoScene.h"
     
    // CLASS IMPLEMENTATIONS
     
    #ifdef __IPHONE_OS_VERSION_MAX_ALLOWED
     
    #pragma mark AppController - iOS
     
    @implementation AppController
     
    - (void) applicationDidFinishLaunching:(UIApplication*)application
    {
    	// CC_DIRECTOR_INIT()
    	//
    	// 1. 初始化一个0bit深度的EAGLView,和一个RGB565的渲染器
    	// 2. EAGLView 多点触摸不使能
    	// 3. 创建一个UIWindow设置其为window变量
    	// 4. 将EAGLView的父类设为新创建的window
    	// 5. 创建显示链接指针
    	// 5a. 如果失败了,会使用一个NSTimer 指针
    	// 6. 运行在60fps
    	// 7. 不现实fps
    	// 8. 设备情况:细节描写(portrait)
    	// 9. 将这个指针连到EAGLView
    	//
    	CC_DIRECTOR_INIT();
     
    	// 获取共享指针...
    	CCDirector *director = [CCDirector sharedDirector];
     
    	//设置景深模式
    	[director setDeviceOrientation:kCCDeviceOrientationLandscapeLeft];
     
    	// 开启显示fps
    	[director setDisplayFPS:YES];
     
    	// 开启高级资源模式 (Retina Display) on iPhone 4 and maintains low res on all other devices
    	if ([UIScreen instancesRespondToSelector:@selector(scale)])
    		[director setContentScaleFactor:[[UIScreen mainScreen] scale]];
     
    	// 为PNG/BMP/TIFF/JPEG/GIF 设置默认文本格式
    	// 可以是 RGBA8888, RGBA4444, RGB5_A1, RGB565
    	// 你可以随时改变.
    	[CCTexture2D setDefaultAlphaPixelFormat:kCCTexture2DPixelFormat_RGBA8888];
     
    	CCScene *scene = [CCScene node];
    	[scene addChild: [nextAction() node]];
     
    	[director runWithScene: scene];
     
    }
     
    // 发生调用,暂停游戏
    -(void) applicationWillResignActive:(UIApplication *)application
    {
    	[[CCDirector sharedDirector] pause];
    }
     
    // 调用被拒绝
    -(void) applicationDidBecomeActive:(UIApplication *)application
    {
    	[[CCDirector sharedDirector] resume];
    }
     
    // 程序将结束
    - (void)applicationWillTerminate:(UIApplication *)application
    {
    	CC_DIRECTOR_END();
    }
     
    // 置于后台
    -(void) applicationDidEnterBackground:(UIApplication*)application
    {
    	[[CCDirector sharedDirector] stopAnimation];
    }
     
    // 置于前台
    -(void) applicationWillEnterForeground:(UIApplication*)application
    {
    	[[CCDirector sharedDirector] startAnimation];
    }
     
    // 清理内存
    - (void)applicationDidReceiveMemoryWarning:(UIApplication *)application
    {
    	[[CCDirector sharedDirector] purgeCachedData];
    }
     
    - (void) dealloc
    {
    	[window release];
    	[super dealloc];
    }
     
    // next delta time will be zero
    -(void) applicationSignificantTimeChange:(UIApplication *)application
    {
    	[[CCDirector sharedDirector] setNextDeltaTimeZero:YES];
    }
     
    @end
     
    #elif defined(__MAC_OS_X_VERSION_MAX_ALLOWED)
     
    #pragma mark AppController - Mac
    @implementation Demo_Mac_PortAppDelegate
     
    @synthesize window=window_, glView=glView_;
     
    - (void)applicationDidFinishLaunching:(NSNotification *)aNotification {
     
    	CCDirector *director = [CCDirector sharedDirector];
     
    	[director setDisplayFPS:YES];
     
    	[director setOpenGLView:glView_];
     
    	// Enable "moving" mouse event. Default no.
    	[window_ setAcceptsMouseMovedEvents:NO];
     
    	[[CCDirector sharedDirector] runWithScene: [DemoScene scene]];
    }
     
    @end
    #endif

    使用applicationDidFinishLaunching方法,你会注意到[[CCDirector shardDirector] runWithScene:[DemoScene scene]]这一行。这一行定义了我们打算令工程开始的视图。在下一部分我会为一个新的Objective-C类列出更多的代码。

    创建新的Objective-C的类

    在此时我们需要创建新的Objective-C的类。右击你的Xcode工程界面上的Classes group,之后点击Add->New File.你会看到下面的对话框:

    点击下一步你会看到:

    我已经命名我的类为DemoScene.m ,注意检查创建相应的DemoScene.h的方框选中。点击finish,可以看到新的类。下面是这两个文件中的代码,如果你对cocos2d熟悉,那么下面的代码你不会陌生:

    DemoScene.h

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    
    //
    //  DemoScene.h
    //  Demo Mac Port
    //
    //  由 Chris Fletcher在2010/24/10创建.
    //  Copyright 2010 __MyCompanyName__. All rights reserved.
    //
     
    #import
    #import "cocos2d.h"
     
    @interface DemoSceneLayer : CCLayer {
     
    	CCDirector *Director;
     
    }
    @end
     
    @interface DemoScene : CCScene {
     
    	DemoSceneLayer *_layer;
     
    }
     
    @property (nonatomic, retain) DemoSceneLayer *layer;
     
    +(id)scene;
     
    @end

    DemoScene.m

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    
    //
    //  DemoScene.m
    //  Demo Mac Port
    //
    //  由 Chris Fletcher在2010/24/10创建.
    //  Copyright 2010 __MyCompanyName__. All rights reserved.
    //
     
    #import "DemoScene.h"
     
    @implementation DemoScene
    @synthesize layer = _layer;
     
    + (id)scene {
     
    	CCScene *scene = [CCScene node];
    	DemoSceneLayer *layer = [DemoSceneLayer node];
    	[scene addChild:layer];
     
    	return scene;
     
    }
     
    - (id) init {
     
    	if ((self = [super init])) {
     
    		self.layer = [DemoSceneLayer node];
    		[self addChild:_layer];
     
    	}
    	return self;
    }
     
    @end
     
    @implementation DemoSceneLayer
     
    - (id)init {
     
    	if ((self = [super init])) {
     
    		CGSize winSize = [CCDirector sharedDirector].winSize;
     
    		CCSprite *starBG = [CCSprite spriteWithFile:@"starbg.png" rect:CGRectMake(0, 0, 960, 640)];
    		starBG.position = ccp(winSize.width/2, winSize.height/2);
    		[self addChild:starBG];
     
    	}
    	return self;
    }
     
    -(void) dealloc {
     
    	[super dealloc];
     
    }
     
    @end

    正如你所看到的,我们为图层(layer)和视图(scene)创建了接口和实现,之后将CCSprite添加到图层中。这是非常基础的Cocos2d功能,但是对于你上手来说足够了。

    目前我们还是不能建造和运行这个工程。还有一些事情要处理,引入一些框架和图片并且作一些修改。下一部分将会涉及我们需要引入的框架。

    引入额外的框架

    这一部分设计我们需要添加的框架以及如何添加框架。我们需要添加的框架如下:

    • QuartzCore.framework
    • OpenGL.framework
    • ApplicationServices.framework
    • libz.dylib

    在Framework上右击,然后点击Add->Existing Frameworks.之后下面的窗口会出现:

    找到QuartzCore.framework然后点击添加,重复该步骤添加剩下的三个。

    在你完成添加之后,Xcode工程界面应该跟下图类似:

    之后我们需要做的就是引入一些图片然后做一些界面的修改。这篇教程比较长,但是我保证快到结尾了。下一部分我会快速讲述需要添加的图片。

    将图片添加到工程中

    在DemoScene.m中使用了CCprite,该CCprite使用了一个名为starBG.png的图片。你可以在这里下载该图片

    Cocos2d资源要求我们的资源文件夹中有一个称作fps_images.png的文件来渲染在底部左边角出现的图片。你可以在解压缩后的Cocos2d/Resources/fonts 文件夹中找到这个文件。

    之后你把这两个文件放到Xcode工程的资源文件夹中。

    此时我们已经完成了对Xcode工程来说必需的步骤,唯一未完成的是使用界面编辑器(Interface Builder)来为我们的MainMenu.xib文件做一些改动。

    MainMenu.xib 与Interface Builder

    在Xcode 工程界面中找到MainMenu.xib。它应该位于你的资源文件夹中。双击这个文件,会启动界面编辑器。

    界面编辑器启动后,首先需要确定程序窗口的大小。为了简化,我设置窗口为960*640大小,因为我的图片本来都是为iPhone4准备的。

    在你调整完大小后,屏幕截图如下:

    你需要在Window Attributes中改变设置。在底部找到One Shot的标志然后不勾选这一项:

    在改变窗口大小和取消One Shot模式之后,我们需要添加一个OpenGL的视图。在library中向下滚动查找OpenGL View。将它拖入你的窗口。你现在可以看到下面的图:

    将该OpenGL视图的大小调整为窗口大小,窗口变化如下:

    现在窗口和Open GL视图大小都是960*640,下面需要对该视图做一些改变。首先,要将该类变为MacGLView。选中OpenGL视图在Identity 标签下将它的名字改为MacGLView。

    下一步,点击Attributes 标签,具体设置如下图所示:

    在你完成上面的修改之后,下面是最后的修改。我们需要在OpenGL View的AppDelegate中创建一个到glView的链接。因此创建这个链接的具体设置如下所示:

    现在我们已经完成了界面编辑,保存退出界面生成器,返回Xcode工程。在此时为在Mac OS X上运行cocos2d程序的准备都完成了,启动你的程序之后你可以看到如下所示的截图:

    恭喜,你已经完成了在Mac OS X上创建程序的基础模块。在创建这个教程的时候我努力使它周密并且希望没有遗漏什么东西。你可以在下面下载该工程文件。

    Demo Mac Port (6.9M)

    这个教程有用么?你已经利用该教程在Mac上创建基于cocos2d的程序了么?期待您的反馈。

    原文作者:Chris Fletcher

    原文链接:http://chris-fletcher.com/2010/10/24/howto-create-a-cocos2d-mac-project/



  • 相关阅读:
    洛谷P1043数字游戏
    luogu P1330 封锁阳光大学
    luoguP1242 新汉诺塔
    luogu P1892 [BOI2003]团伙
    luogu P3375 【模板】KMP字符串匹配
    luoguP1440 求m区间内的最小值
    luoguP2700 逐个击破
    luoguP2814 家谱
    luogu P1962 斐波那契数列
    P3379 【模板】最近公共祖先(LCA)
  • 原文地址:https://www.cnblogs.com/java20130723/p/3212272.html
Copyright © 2011-2022 走看看