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

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

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

static MenuItemSprite* create  ( Node * normalSprite,  //菜单项正常显示时候的精灵
 Node *  selectedSprite,                                               //选择菜单项时候的精灵
 Node *  disabledSprite,                                               //菜单项禁用时候的精灵
 const ccMenuCallback & callback                             //菜单操作的回调函数指针
 )

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

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

static MenuItemImage* create  ( const std::string &  normalImage, //菜单项正常显示时候的图片
 const std::string & selectedImage,                                                        //选择菜单项时候的图片
 const std::string & disabledImage,                                              //菜单项禁用时候的图片
 const ccMenuCallback & callback                                                        //菜单操作的回调函数指针
 )

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

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

下面我们看看HelloWorldScene.cpp中init函数如下

bool HelloWorld::init()
{
   if ( !Layer::init() )
   {
       return false;
   }

   Size visibleSize = Director::getInstance()->getVisibleSize();
   Point origin = Director::getInstance()->getVisibleOrigin();

   Sprite *bg = Sprite::create("menu/background.png");
   bg->setPosition(Point(origin.x + visibleSize.width/2,
                             origin.y + visibleSize.height/2));
   this->addChild(bg);

    //开始精灵
   Sprite *startSpriteNormal =Sprite::create("menu/start-up.png");                                     ①
   Sprite *startSpriteSelected =Sprite::create("menu/start-down.png");                                      ②

    MenuItemSprite*startMenuItem = MenuItemSprite::create(startSpriteNormal,
                                        startSpriteSelected,
         CC_CALLBACK_1(HelloWorld::menuItemStartCallback,this));                                     ③
    startMenuItem->setPosition(Director::getInstance()->convertToGL(Point(700,170)));             ④

    //设置图片菜单
  MenuItemImage *settingMenuItem = MenuItemImage::create(
                            "menu/setting-up.png",
                            "menu/setting-down.png",
                             CC_CALLBACK_1(HelloWorld::menuItemSettingCallback,this));             ⑤
    settingMenuItem->setPosition(Director::getInstance()->convertToGL(Point(480,400)));                  ⑥

    //帮助图片菜单
   MenuItemImage *helpMenuItem = MenuItemImage::create(
                            "menu/help-up.png",
                            "menu/help-down.png",
                                  CC_CALLBACK_1(HelloWorld::menuItemHelpCallback,this));                      ⑦
    helpMenuItem->setPosition(Director::getInstance()->convertToGL(Point(860,480)));            ⑧

    Menu*mu = Menu::create(startMenuItem, settingMenuItem, helpMenuItem, NULL);                  ⑨
    mu->setPosition(Point::ZERO);                                                                                                    ⑩
    this->addChild(mu);

   return true;
}

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

bool HelloWorld::init()
{
   if ( !Layer::init() )
   {
       return false;
   }

   Size visibleSize = Director::getInstance()->getVisibleSize();
   Point origin = Director::getInstance()->getVisibleOrigin();

   Sprite *bg = Sprite::create("menu/background.png");
   bg->setPosition(Point(origin.x + visibleSize.width/2,
                             origin.y + visibleSize.height/2));
   this->addChild(bg);

    //开始精灵
   Sprite *startSpriteNormal =Sprite::create("menu/start-up.png");                                     ①
   Sprite *startSpriteSelected =Sprite::create("menu/start-down.png");                                      ②

    MenuItemSprite*startMenuItem = MenuItemSprite::create(startSpriteNormal,
                                        startSpriteSelected,
         CC_CALLBACK_1(HelloWorld::menuItemStartCallback,this));                                     ③
    startMenuItem->setPosition(Director::getInstance()->convertToGL(Point(700,170)));             ④

    //设置图片菜单
  MenuItemImage *settingMenuItem = MenuItemImage::create(
                            "menu/setting-up.png",
                            "menu/setting-down.png",
                             CC_CALLBACK_1(HelloWorld::menuItemSettingCallback,this));             ⑤
    settingMenuItem->setPosition(Director::getInstance()->convertToGL(Point(480,400)));                  ⑥

    //帮助图片菜单
   MenuItemImage *helpMenuItem = MenuItemImage::create(
                            "menu/help-up.png",
                            "menu/help-down.png",
                                  CC_CALLBACK_1(HelloWorld::menuItemHelpCallback,this));                      ⑦
    helpMenuItem->setPosition(Director::getInstance()->convertToGL(Point(860,480)));            ⑧

    Menu*mu = Menu::create(startMenuItem, settingMenuItem, helpMenuItem, NULL);                  ⑨
    mu->setPosition(Point::ZERO);                                                                                                    ⑩
    this->addChild(mu);

   return true;
}

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


boolAppDelegate::applicationDidFinishLaunching() {
   // initialize director
   auto director = Director::getInstance();
   auto glview = director->getOpenGLView();
   if(!glview) {
       glview = GLView::create("My Game");
             glview->setFrameSize(1136, 640);                                                                              ①
       director->setOpenGLView(glview);
   }

… …
}

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

上述代码中的第①行定义的函数menuOkCallback是在用户在设置场景点击“OK”菜单时候回调。第②行代码是使用popScene函数返回HelloWorld场景。

更多内容请关注最新Cocos图书《Cocos2d-x实战 C++卷》
本书交流讨论网站http://www.cocoagame.net

更多精彩视频课程请关注智捷课堂Cocos课程http://v.51work6.com

欢迎加入Cocos2d-x技术讨论群257760386

《Cocos2d-x实战 C++卷》现已上线各大商店均已开售

京东http://item.jd.com/11584534.html

亚马逊http://www.amazon.cn/Cocos2d-x%E5%AE%9E%E6%88%98-C-%E5%8D%B7-%E5%85%B3%E4%B8%9C%E5%8D%87/dp/B00PTYWTLU

当当http://product.dangdang.com/23606265.html

互动出版网http://product.china-pub.com/3770734

《Cocos2d-x实战 C++卷》源码及样章下载地址

源码下载地址http://51work6.com/forum.php?mod=viewthread&tid=1155&extra=page%3D1 

样章下载地址http://51work6.com/forum.php?mod=viewthread&tid=1157&extra=page%3D1

欢迎关注智捷iOS课堂微信公共平台

时间: 2025-01-20 11:45:22

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

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

精灵菜单的菜单项类是cc.MenuItemSprite,图片菜单的菜单项类是cc.MenuItemImage.由于cc.MenuItemImage继承于cc.MenuItemSprite,所以图片菜单也属于精灵菜单.为什么叫精灵菜单呢?那是因为这些菜单项具有精灵的特点,我们可以让精灵动起来,具体使用时候是把一个精灵放置到菜单中作为菜单项.精灵菜单项类cc.MenuItemSprite,它的其中一个构造函数定义如下: ctor(normalSprite, //菜单项正常显示时候的精灵 select

实例介绍Cocos2d-x开关菜单

开关菜单是MenuItemToggle类实现的它是一种可以进行两种状态切换的菜单.它可以通过下面的函数创建 static MenuItemToggle*createWithCallback ( const ccMenuCallback & callback, //菜单操作的回调函数指针 MenuItem * item, //进行切换的菜单项 ... ) 从第二个参数开始都是MenuItem类的实例对象它们是开关菜单显示的菜单项它们可以是文本.图片和精灵类型的菜单项但是最后不用忘记NULL结尾.

cocos2d x-cocos2dx 精灵 图片 的问题

问题描述 cocos2dx 精灵 图片 的问题 我创建了一个精灵,显示的是图片的一部分,现在想实现鼠标点击后,这个精灵显示图片的另一部分,就是更改一下图片的坐标,但是精灵的大小和位置不变,请问有什么函数能实现这样的功能? 解决方案 cocos2dx的setVisible不行吗 解决方案二: changeFrame之类的,更改精灵的显示图片,具体函数不记得了 解决方案三: 如果,你是自己写了一个控件的话,比如:一个继承自Node的类,有一个Sprite的属性,点击Node相应Node的点击函数,改

android中选中菜单的显示跳转和隐式跳转的实例介绍

查了好多资料,现发还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记录吧! 简介 android供给了三种菜单类型,分别为options menu,context menu,sub menu. options menu就是通过按home键来表现,context menu需要在view上按上2s后表现.这两种menu都有可以参加子菜单,子菜单不能种不能嵌套子菜单.options menu最多只能在幕屏最下面表现6个菜单项选,称为iconmenu,icon menu不

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

下面我们通过一个实例介绍一下帧动画的使用这个实例如下图所示点击Go按钮开始播放动画这时候播放按钮标题变为Stop点击Stop按钮可以停止播放动画. 下面我们再看看具体的程序代码首先看一下看HelloWorldScene.h文件它的代码如下 #ifndef __HELLOWORLD_SCENE_H__ #define __HELLOWORLD_SCENE_H__ #include "cocos2d.h" class HelloWorld : public cocos2d::Layer {

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

下面我们通过一个实例介绍几个特效的使用这个实例下图所示下图是一个操作菜单场景选择菜单可以进入到下图动作场景在下图动作场景中点击Go按钮可以执行我们选择的特性动作点击Back按钮可以返回到菜单场景. 下面我们再看看具体的程序代码首先看一下看HelloWorldScene.h文件它的代码如下 #ifndef __HELLOWORLD_SCENE_H__ #define __HELLOWORLD_SCENE_H__ #include "cocos2d.h" #include "My

photoshop碎片滤镜的使用实例介绍

  photoshop作为图片处理工具的佼佼者,今天小编教大家photoshop碎片滤镜的使用,教程比较基础,希望能对大家有所帮助! 方法/步骤 如图所示,我们点击箭头所指的photoshop软件图标,打开photoshop软件. 如图所示,我们点击箭头所指的"文件"这一项. 如图所示,在弹出的列表菜单中,我们点击箭头所指的"打开(O)..."这一项. 如图所示,我们选择一张图片,接下来我们点击箭头所指的"打开"按钮. 如图所示,点击"

实例介绍Cocos2d-x物理引擎:HelloPhysicsWorld

我们通过一个实例介绍一下在Cocos2d-x 3.x中使用物理引擎的开发过程熟悉这些API的使用.这个实例的运行后的场景当场景启动后玩家可以触摸点击屏幕每次触摸时候就会在触摸点生成一个新的精灵精灵的运行是自由落体运动. HelloPhysicsWorld实例 使用物理引擎的一般步骤如下图所示. 这个过程与上帝创建世界的过程类似上帝首先创建了世界然后为世界指定了边界否则万物就会掉到世界之外的混沌里去了最后上帝创建了万物.当然这只是一个最基本的步骤有的时候还需要碰撞检测和使用关节等处理.下面我们就按

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

碰撞检测是使用物理引擎的一个重要目的使用物理引擎可以进行精确的碰撞检测而且执行的效率也很高.在Cocos2d-x 3.x中使用事件派发机制管理碰撞事件EventListenerPhysicsContact是碰撞事件监听器.碰撞检测相关的API我们在前面一节介绍过了下面通过一个实例介绍碰撞检测的实现.这个实例的运行后的场景如图所示当场景启动后玩家可以触摸点击屏幕每次触摸时候就会在触摸点生成一个新的精灵精灵的运行是自由落体运动.当这些精灵之间发生接触时候它们的颜色被设置为黄色分离后颜色又恢复到原来状