`

实例介绍Cocos2d-x精灵菜单和图片菜单

阅读更多

精灵菜单类是MenuItemSprite,图片菜单类是MenuItemImage。由于MenuItemImage继承于MenuItemSprite,所以图片菜单也属于精灵菜单。为什么叫精灵菜单呢?那是因为这些菜单项具有精灵的特点,我们可以让精灵动起来,具体使用时候是把一个精灵放置到菜单中作为菜单项。

精灵菜单类MenuItemSprite,它的其中一个创建函数create定义如下:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <span style="font-size:14px;">static MenuItemSprite* create  ( Node * normalSprite,  //菜单项正常显示时候的精灵  
  2.  Node *  selectedSprite,                                               //选择菜单项时候的精灵  
  3.  Node *  disabledSprite,                                               //菜单项禁用时候的精灵  
  4.  const ccMenuCallback & callback                             //菜单操作的回调函数指针  
  5.  )</span>  

 

 

使用MenuItemSprite比较麻烦,在创建MenuItemSprite之前要先创建三种状态时候的精灵(即normalSpriteselectedSpritedisabledSprite)。MenuItemSprite还有一些create函数,在这些函数中可以省略disabledSprite参数。

如果精灵是由图片构成的,我们可以使用图片菜单MenuItemImage实现与精灵菜单同样的效果。MenuItemImage类的其中一个创建函数create定义如下:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <span style="font-size:14px;">static MenuItemImage* create  ( const std::string &  normalImage, //菜单项正常显示时候的图片  
  2.  const std::string & selectedImage,                                                        //选择菜单项时候的图片  
  3.  const std::string & disabledImage,                                              //菜单项禁用时候的图片  
  4.  const ccMenuCallback & callback                                                        //菜单操作的回调函数指针  
  5.  )</span>  

 

 

MenuItemImage还有一些create函数,在这些函数中可以省略disabledImage参数。

我们通过一个实例介绍一下精灵菜单和图片菜单的使用,这个实例如下图所示。

 

下面我们看看HelloWorldScene.cppinit函数如下:

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <span style="font-size:14px;">bool HelloWorld::init()  
  2. {  
  3.    if ( !Layer::init() )  
  4.    {  
  5.        return false;  
  6.    }  
  7.      
  8.    Size visibleSize = Director::getInstance()->getVisibleSize();  
  9.    Point origin = Director::getInstance()->getVisibleOrigin();  
  10.    
  11.    Sprite *bg = Sprite::create("menu/background.png");     
  12.    bg->setPosition(Point(origin.x + visibleSize.width/2,  
  13.                              origin.y + visibleSize.height/2));  
  14.    this->addChild(bg);  
  15.    
  16.     //开始精灵  
  17.    Sprite *startSpriteNormal =Sprite::create("menu/start-up.png");                                     ①  
  18.    Sprite *startSpriteSelected =Sprite::create("menu/start-down.png");                                      ②  
  19.    
  20.     MenuItemSprite*startMenuItem = MenuItemSprite::create(startSpriteNormal,  
  21.                                         startSpriteSelected,  
  22.          CC_CALLBACK_1(HelloWorld::menuItemStartCallback,this));                                     ③  
  23.     startMenuItem->setPosition(Director::getInstance()->convertToGL(Point(700,170)));             ④  
  24.      
  25.     //设置图片菜单  
  26.   MenuItemImage *settingMenuItem = MenuItemImage::create(  
  27.                             "menu/setting-up.png",  
  28.                             "menu/setting-down.png",  
  29.                              CC_CALLBACK_1(HelloWorld::menuItemSettingCallback,this));             ⑤  
  30.     settingMenuItem->setPosition(Director::getInstance()->convertToGL(Point(480,400)));                  ⑥  
  31.      
  32.     //帮助图片菜单  
  33.    MenuItemImage *helpMenuItem = MenuItemImage::create(  
  34.                             "menu/help-up.png",  
  35.                             "menu/help-down.png",  
  36.                                   CC_CALLBACK_1(HelloWorld::menuItemHelpCallback,this));                      ⑦  
  37.     helpMenuItem->setPosition(Director::getInstance()->convertToGL(Point(860,480)));            ⑧  
  38.    
  39.     Menu*mu = Menu::create(startMenuItem, settingMenuItem, helpMenuItem, NULL);                  ⑨  
  40.     mu->setPosition(Point::ZERO);                                                                                                    ⑩  
  41.     this->addChild(mu);  
  42.    
  43.    return true;  
  44. }</span>  

 

 

在上面的代码中第①~②行是创建两种不同状态的精灵,第③行代码是创建精灵菜单MenuItemSprite对象,第④行代码是设置开始菜单项(startMenuItem)位置,注意这个坐标是(700,170),由于(700, 170)的坐标是UI坐标,需要转换为OpenGL坐标。

第⑤和⑦行代码是创建图片菜单MenuItemImage对象,第⑥和⑧行代码是设置图片菜单位置。第⑨行代码是菜单Menu对象,第⑩行代码是菜单的位置mu->setPosition(Point::ZERO),设置的位置是Point::ZERO,它等价于Point(0.0f,0.0f)

还有由于背景图片大小是1136 x 640,而Win32默认窗口大小是960 x 640,我们需要重新设置大小,修改AppDelegate.cpp代码如下:

 

 

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. bool HelloWorld::init()  
  2. {  
  3.    if ( !Layer::init() )  
  4.    {  
  5.        return false;  
  6.    }  
  7.      
  8.    Size visibleSize = Director::getInstance()->getVisibleSize();  
  9.    Point origin = Director::getInstance()->getVisibleOrigin();  
  10.    
  11.    Sprite *bg = Sprite::create("menu/background.png");     
  12.    bg->setPosition(Point(origin.x + visibleSize.width/2,  
  13.                              origin.y + visibleSize.height/2));  
  14.    this->addChild(bg);  
  15.    
  16.     //开始精灵  
  17.    Sprite *startSpriteNormal =Sprite::create("menu/start-up.png");                                     ①  
  18.    Sprite *startSpriteSelected =Sprite::create("menu/start-down.png");                                      ②  
  19.    
  20.     MenuItemSprite*startMenuItem = MenuItemSprite::create(startSpriteNormal,  
  21.                                         startSpriteSelected,  
  22.          CC_CALLBACK_1(HelloWorld::menuItemStartCallback,this));                                     ③  
  23.     startMenuItem->setPosition(Director::getInstance()->convertToGL(Point(700,170)));             ④  
  24.      
  25.     //设置图片菜单  
  26.   MenuItemImage *settingMenuItem = MenuItemImage::create(  
  27.                             "menu/setting-up.png",  
  28.                             "menu/setting-down.png",  
  29.                              CC_CALLBACK_1(HelloWorld::menuItemSettingCallback,this));             ⑤  
  30.     settingMenuItem->setPosition(Director::getInstance()->convertToGL(Point(480,400)));                  ⑥  
  31.      
  32.     //帮助图片菜单  
  33.    MenuItemImage *helpMenuItem = MenuItemImage::create(  
  34.                             "menu/help-up.png",  
  35.                             "menu/help-down.png",  
  36.                                   CC_CALLBACK_1(HelloWorld::menuItemHelpCallback,this));                      ⑦  
  37.     helpMenuItem->setPosition(Director::getInstance()->convertToGL(Point(860,480)));            ⑧  
  38.    
  39.     Menu*mu = Menu::create(startMenuItem, settingMenuItem, helpMenuItem, NULL);                  ⑨  
  40.     mu->setPosition(Point::ZERO);                                                                                                    ⑩  
  41.     this->addChild(mu);  
  42.    
  43.    return true;  
  44. }  

在上面的代码中第①~②行是创建两种不同状态的精灵,第③行代码是创建精灵菜单MenuItemSprite对象,第④行代码是设置开始菜单项(startMenuItem)位置,注意这个坐标是(700,170),由于(700, 170)的坐标是UI坐标,需要转换为OpenGL坐标。

第⑤和⑦行代码是创建图片菜单MenuItemImage对象,第⑥和⑧行代码是设置图片菜单位置。第⑨行代码是菜单Menu对象,第⑩行代码是菜单的位置mu->setPosition(Point::ZERO),设置的位置是Point::ZERO,它等价于Point(0.0f,0.0f)

还有由于背景图片大小是1136 x 640,而Win32默认窗口大小是960 x 640,我们需要重新设置大小,修改AppDelegate.cpp代码如下:

 

 

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. <pre code_snippet_id="340364" snippet_file_name="blog_20140512_5_4431376" name="code" class="html">boolAppDelegate::applicationDidFinishLaunching() {  
  2.    // initialize director  
  3.    auto director = Director::getInstance();  
  4.    auto glview = director->getOpenGLView();  
  5.    if(!glview) {  
  6.        glview = GLView::create("My Game");  
  7.              glview->setFrameSize(1136, 640);                                                                              ①  
  8.        director->setOpenGLView(glview);  
  9.    }  
  10.    
  11. … …  
  12. }</pre>  
[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1.   

我们需要在第①行添加glview->setFrameSize(1136, 640)代码。

分享到:
评论

相关推荐

    cocos2d-x游戏实例-纵版射击游戏

    【cocos2d-x游戏实例-纵版射击游戏】是一个基于Cocos2d-x框架开发的垂直滚动射击游戏,这种类型的游戏通常被称为“飞行射击”或“弹幕射击”。Cocos2d-x是一个广泛使用的开源游戏开发框架,它支持多平台开发,包括...

    cocos2d-x 实例源码

    本实例“愤怒的松鼠”是基于cocos2d-x框架编写的一款游戏,提供了完整的源代码,对于学习和理解cocos2d-x的使用方法以及游戏开发流程具有极高的参考价值。 首先,让我们深入了解cocos2d-x的核心特性。cocos2d-x提供...

    cocos2d-x 摇杆

    cocos2d-x提供了丰富的API,使得开发者能够方便地创建游戏场景、精灵、动作和交互事件。 【ccjoystick】是cocos2d-x中用于实现摇杆功能的组件,通常包括两个部分:摇杆基座和可移动的滑块。基座固定在屏幕的某个...

    flappy bird 基于cocos2d-x 3.8

    本教程将详细介绍如何使用Cocos2d-x 3.8框架来开发类似Flappy Bird的游戏,这对于初学者来说是一次很好的实践机会,能够深入理解游戏开发的基本原理和Cocos2d-x引擎的使用。 Cocos2d-x是一款开源的2D游戏开发框架,...

    cocos2d-x高仿微信打飞机

    3. **cocos2d-x编程基础**:初学者可以通过这个游戏学习到cocos2d-x的基本编程概念,如精灵(Sprite)、层(Layer)、场景(Scene)、动作(Action)和物理世界(PhysicsWorld)的使用。此外,还需理解节点树结构、...

    cocos2dx_study.rar_cocos2d-x_cocos2d-x实例_cocos2dx

    Cocos2d-x是一个开源的游戏开发框架,它基于C++,但同时也支持Lua和JavaScript等脚本语言,让开发者能够快速地创建跨平台的游戏。本资料集合旨在为初学者提供一个全面的cocos2d-x学习路径,从环境搭建到实际项目开发...

    Cocos2d-X斗地主游戏完整源码

    这个“Cocos2d-X斗地主游戏完整源码”是一个利用Cocos2d-X框架构建的斗地主游戏项目,包含了从新手到大师五个级别的游戏体验,旨在提供给开发者一个学习和参考的实例。 1. **Cocos2d-X框架**:Cocos2d-X是跨平台的...

    cocos2d-x《魔塔》中期(版本2.2.2)

    《cocos2d-x手机游戏开发--跨iOS、Android和沃Phone平台》是一本深入讲解cocos2d-x游戏引擎的书籍,其中包含了利用该引擎创建跨平台游戏的实例。在这一实例中,我们聚焦于“魔塔”游戏的中期开发阶段,使用的cocos2d...

    《Cocos2d-Js开发之旅-从HTML5到原生手机游戏》完整源码

    Cocos2d-Js是Cocos2d-x家族的一员,是一个跨平台的、基于JavaScript的开源游戏引擎,支持创建2D游戏、交互式图书和其他富媒体应用。通过Cocos2d-Js,开发者可以用一种语言编写代码,然后在多个平台上运行,包括Web、...

    cocos2d-x游戏实例 萝莉快跑

    7. **资源加载与管理**:在"萝莉快跑"中,可能使用了cocos2d-x的资源管理器来组织和加载游戏资源,如图片、音频和XML配置文件等,保证了资源的有效利用和快速访问。 【文件名称列表】:"example12-1" 由于提供的...

    COCOS2D-X 2.2 实例 瞄星大战

    《COCOS2D-X 2.2 实例:瞄星大战》是基于Cocos2d-x游戏开发框架的一个经典实例,旨在帮助开发者理解和掌握如何使用Cocos2d-x 2.2版本来构建游戏。Cocos2d-x是一款开源的游戏引擎,广泛应用于2D游戏的开发,尤其在...

    cocos2d-x封神榜demo源码

    《cocos2d-x封神榜demo源码》是一个基于cocos2d-x游戏引擎开发的项目,旨在为初学者提供一个深入理解游戏开发过程的实例。cocos2d-x是一个开源的、跨平台的2D游戏开发框架,广泛应用于iOS、Android、Windows等多平台...

    cocos2d-x_学习文档

    在资源管理方面,cocos2d-x支持图片、音频、字体等资源的加载和释放,通过`CCSpriteBatchNode`可以优化大量精灵的渲染效率。音效和音乐可以通过`CCTouchDispatcher`进行播放控制。 总之,cocos2d-x是一个功能丰富的...

    魔塔cocos2d-x源码

    1. **游戏场景管理**:Cocos2d-x中的Scene类代表游戏的一个屏幕或阶段,源码中会展示如何创建和切换不同的游戏场景,如主菜单、游戏地图、战斗界面等。 2. **精灵(Sprite)与图层(Layer)**:在游戏开发中,精灵...

    cocos2d-x手机游戏开发

    《cocos2d-x手机游戏开发》一书由徐松林和黄猛共同编著,是初学者入门Cocos2d-x游戏开发的优选指南。人民邮电出版社于2011年12月出版,全书共195页,涵盖了从基础到实践的多个重要知识点。 1. **Cocos2d-x简介**:...

    《cocos2d-x权威指南》第12章实例代码

    《cocos2d-x权威指南》是学习Cocos2d-x游戏引擎开发的重要参考资料,而第12章的实例代码则是深入理解Cocos2d-x功能和应用的关键部分。本章可能涵盖了游戏场景管理、精灵动画、物理引擎、用户交互、音频处理等多个...

    自己写的cocos2d-x的小demo

    Cocos2d-x是一款开源的游戏开发框架,基于C++,并提供了Lua和JavaScript的绑定,使得开发者能够用这些语言进行游戏开发。这个“自己写的cocos2d-...对于初学者来说,这是一个很好的学习和研究Cocos2d-x实际应用的实例。

    FlappyBird-cocos2dx-master_TheMaster_cocos2d-x_

    cocos2d-x提供了一系列游戏开发所需的核心功能,如场景管理、精灵、动画、物理引擎、触摸事件处理等。 首先,我们要了解cocos2d-x的项目结构。在"FlappyBird-cocos2dx-master"这个压缩包中,包含了项目的源代码、...

Global site tag (gtag.js) - Google Analytics