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

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

  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之前要先创建三种状态时候的精灵(即normalSprite、selectedSprite和disabledSprite)。MenuItemSprite还有一些create函数,在这些函数中可以省略disabledSprite参数。

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

  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.cpp中init函数如下:

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

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

在上面的代码中第①~②行是创建两种不同状态的精灵,第③行代码是创建精灵菜单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代码如下:

  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. }</pre>

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

实例介绍Cocos2d-x精灵菜单和图片菜单的更多相关文章

  1. Cocos2d-JS中的精灵菜单和图片菜单

    精灵菜单的菜单项类是cc.MenuItemSprite,图片菜单的菜单项类是cc.MenuItemImage.由于cc.MenuItemImage继承于cc.MenuItemSprite,所以图片菜单 ...

  2. 实例介绍Cocos2d-x开关菜单

    开关菜单是MenuItemToggle类实现的,它是一种可以进行两种状态切换的菜单.它可以通过下面的函数创建: static MenuItemToggle*createWithCallback  ( ...

  3. 【转】Android实例剖析笔记(二)--用实例讲解Andriod的开发过程,以NotesList为实例介绍Android的菜单机制

    原文网址:http://kb.cnblogs.com/page/78304/ 简介 android提供了三种菜单类型,分别为options menu,context menu,sub menu. op ...

  4. Cocos2d-x开发实例介绍帧动画使用

    下面我们通过一个实例介绍一下帧动画的使用,这个实例如下图所示,点击Go按钮开始播放动画,这时候播放按钮标题变为Stop,点击Stop按钮可以停止播放动画. 下面我们再看看具体的程序代码,首先看一下看H ...

  5. Cocos2d-x开发实例介绍特效演示

    下面我们通过一个实例介绍几个特效的使用,这个实例下图所示,下图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜单 ...

  6. Cocos2d-x中__Dictionary容器以及实例介绍

    __Dictionary类在Cocos2d-x 2.x时代它就是CCDictionary类,它是模仿Objective-C中的NSDictionary类而设计的,通过引用计数管理内存.__Dictio ...

  7. Cocos2d-x中__Array容器以及实例介绍

    __Array类在Cocos2d-x 2.x时代它就是CCArray类.它是模仿Objective-C中的NSArray类而设计的,通过引用计数管理内存.__Array继承于Ref类,因此它所能容纳的 ...

  8. 实例介绍Cocos2d-x中Box2D物理引擎:HelloBox2D

    我们通过一个实例介绍一下,在Cocos2d-x 3.x中使用Box2D物理引擎的开发过程,熟悉这些API的使用.这个实例运行后的场景如图所示,当场景启动后,玩家可以触摸点击屏幕,每次触摸时候,就会在触 ...

  9. 实例介绍Cocos2d-x物理引擎:碰撞检测

    碰撞检测是使用物理引擎的一个重要目的,使用物理引擎可以进行精确的碰撞检测,而且执行的效率也很高.在Cocos2d-x 3.x中使用事件派发机制管理碰撞事件,EventListenerPhysicsCo ...

随机推荐

  1. C#生成软件注册码

    开发软件时,当用到商业用途时,注册码与激活码就显得很重要了.现在的软件破解技术实在在强了,各种国内外大型软件都有注册机制,但同时也不断地被破解.下面发的只是一个常用版本,发出源码被破就更容易了,但我们 ...

  2. change netbeans look and feel

    change netbeans look and feel: 方法一: 下载地址:https://kenai.com/projects/nbsubstance/downloads/directory/ ...

  3. android中broadcastreceiver的用法-代码中注册

    界面如下:     问题1:点击“解绑广播接收器“后再次点击”解绑广播接收器“后,程序崩溃,log信息如下: 08-04 05:04:35.420: E/AndroidRuntime(5521): F ...

  4. Oracle—用户管理的完全恢复(四)

    在用户管理的备份(三)中,最后打开数据库时,用了alter database open resetlogs;的命令,这里为什么用resetlogs命令? 一.resetlogs的作用 1.将当前的日志 ...

  5. linux上一些命令

    ps -ef看看有没有tomcat的进程:也可以用netstat -tnl来看tomcat的端口是否开放

  6. LeetCode16 3Sum Closest

    题意: Given an array S of n integers, find three integers in S such that the sum is closest to a given ...

  7. ubuntu14.04编译mono源码(有坑...)

     从github上下载了mono的源码,然后打算编译了.百度了一下教程,我去...居然没有教程.换bing搜索一下,我去...还是没有.关键字换一下:how to build mono on linu ...

  8. IOS 开发过程中的 消息通知 小红点

    大致分为两种方法:系统方法和自定义方法 系统方法: 系统自带的方法可以显示具体的消息数量,这个就是苹果设备常见的小红点.实现思路如下: NSArray *tabBarItems = self.navi ...

  9. .Net中的socket编程例子

    vb2010: '发送端代码Public Class Form1    Inherits System.Windows.Forms.FormPrivate Sub Button1_Click(ByVa ...

  10. shell 获取cpu使用率

    1.shell脚本获取主机每颗CPU使用率的方法. #!/bin/bash interval= cpu_num=`-] -c` start_idle=() start_total=() cpu_rat ...