`

实例介绍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实战:JS卷——Cocos2d-JS开发

    资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...

    cocos2d-x-2.1.5

    cocos2d-x-2.1.5

    cocos2d-x事件类

    在使用cocos2d-x开发游戏的过程中,为了实现逻辑和显示相分离。 在下通宵了一个晚上,写出了该事件类。 谨记,该事件只能用于cocos2d-x中。 事件发送者需要继承EventDispatcher类 事件接收者需要继承EventHandle类...

    Cocos2d-x高级开发教程

    书中汇聚了热门手机游戏《捕鱼达人》开发的实战经验,作者从最基础的内容开始,逐步深入地介绍了Cocos2d-x的相关知识点。此外,书中的教学资源获得《捕鱼达人》手机游戏的授权,读者可以从一流游戏开发中高起点地...

    实例妙解Cocos2D-X游戏开发

    一线资深游戏开发工程师根据Cocos2D-X 最新版本撰写,Cocos2D...完全通过真实游戏案例驱动,不仅将Cocos2D-X的各种功能、原理、技巧融入其中,而且还详细讲解了空战类、塔防类、物理类游戏的开发过程和方法,实战性极强

    大富翁手机游戏开发实战基于Cocos2d-x3.2引擎

    资源名称:大富翁手机游戏开发实战基于Cocos2d-x3.2引擎内容简介:李德国编著的《大富翁手机游戏开发实战(基于 Cocos2d-x3.2引擎)》使用Cocos2d-x游戏引擎技术,带领读者一步一步从零开始进行大富翁移动游戏的开发...

    cocos2d-x-3.2旧版引擎下载

    cocos2d-x-3.2下载,不多说。或者可以下载另一个资源 cocos引擎老版本集合(cocos2d-x-2.2.1 - 3.5) http://download.csdn.net/download/crazymagicdc/9982656

    cocos2d-x实战项目

    cocos2d-x实战项目 01.cocos2d-x原理及环境配置.rar 03.cocostudio使用方法及UI控制.rar 04.XML文件读取与骨骼动画.rarcocos2d-x实战项目 01.cocos2d-x原理及环境配置.rar 03.cocostudio使用方法及UI控制.rar 04.XML...

    Cocos2D-X游戏开发技术精解

     《Cocos2D-X游戏开发技术精解》详细介绍如何使用Cocos2D-X引擎开发自己的移动平台游戏。全书共15章,主要内容包括:Cocos2D-X引擎简介;如 资源太大,传百度网盘了,链接在附件中,有需要的同学自取。

    Cocos2d-x 3.x游戏开发之旅

    本书是《Cocos2d-x 游戏开发之旅》的升级版,修改了2.0版进阶到3.0版后的一些内容...通过2到3个游戏实例介绍Cocos2d-x在实际开发中的应用;手机网络游戏开发入门;介绍在实际的手游开发过程中遇到的问题以及解决方法。

    经典版本 方便下载 源码 旧版本 3.8 官网找不到了 cocos2d-x-3.8.zip

    经典版本 方便下载 源码 旧版本 3.8 官网找不到了 cocos2d-x-3.8.zip

    精通COCOS2D-X游戏开发 基础卷_2016.4-P399-13961841.pdf

    精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发

    cocos2d-x-3.0 类图

    这是我重新弄的cocos2d-x-3.0的类图.之前别人兄台弄的,有些不全面,有些地方错误.我这个可以说是最新的了.每个类添加了中文的详细注解,同时也添加了中文的类名称翻译.这样对cocos2d-x-3.0的框架比较好上手. 有兴趣的...

    Cocos2D-X游戏开发技术精解.pdf

    《Cocos2D-X游戏开发技术精解》详细介绍如何使用Cocos2D-X引擎开发自己的移动平台游戏。全书共15章,主要内容包括:Cocos2D-X引擎简介;如何建立跨平台的开发环境;引擎的核心模块——渲染框架;如何实现动态画面和...

    Cocos2d-x 3.x游戏开发实战pdf含目录

    Cocos2d-x 3.x游戏开发实战pdf含目录,内容详细,强烈推荐给大家。

    cocos2d-x 3.0

    cocos2d-x 3.0 人物行走 . 包里有代码和 图片资源.

    cocos2d-x windows vs2010配置

    Cocos2d-x windows vs2010 配置图文详解

    Cocos2d-x 游戏资源(图片、XML、TXT等)打包加密 之 解密读取

    Cocos2d-x 游戏资源(图片、XML、TXT等)打包加密 之 解密读取

    cocos2d-x 动画工具 Flash2Cocos2d-x 1.3

    cocos2d-x 动画工具 Flash2Cocos2d-x 1.3

    Cocos2d-x实战 JS卷 Cocos2d-JS开发

    Cocos2d-x实战 JS卷 Cocos2d-JS开发 PDF 电子书完整版本

Global site tag (gtag.js) - Google Analytics