Cocos2d-x MenuItemToggle 实现开关按钮

前端之家收集整理的这篇文章主要介绍了Cocos2d-x MenuItemToggle 实现开关按钮前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

最近做自己的塔防游戏的时候用到的,作为记录记载下来。

MenuItemToggle可以实现按钮的开关两种状态,类似”ON”->”OFF”.

void SettingScene::addMenuItems(){
    auto size=Director::getInstance()->getWinSize();

    /*添加返回按钮*/
    auto backMenuItem=MenuItemImage::create(
        "SettingSceneImages/backMenuItem_1.png","SettingSceneImages/backMenuItem_2.png",CC_CALLBACK_1(SettingScene::menuBackCallback,this));
    backMenuItem->setPosition(Point(size.width-backMenuItem->getContentSize().width/2,backMenuItem->getContentSize().height/2));
    this->addChild(backMenuItem,1);

    auto startWidth=backMenuItem->getContentSize().width+80; //起始横坐标(左上方第一个) 
    auto startHeight=size.height-backMenuItem->getContentSize().height/2-20; //起始纵坐标

    /*添加"打开\关闭音乐"按钮*/
    _openMusicItem=MenuItemImage::create(
        "SettingSceneImages/openMusicItem_1.png","SettingSceneImages/openMusicItem_2.png"
        );
    _closeMusicItem=MenuItemImage::create(
        "SettingSceneImages/closeMusicItem_1.png","SettingSceneImages/closeMusicItem_2.png");
    //组合按钮
    auto setMusicMenuToggle=MenuItemToggle::createWithCallback(CC_CALLBACK_1(SettingScene::menuSetMusicCallback,this),_openMusicItem,_closeMusicItem,NULL);
    setMusicMenuToggle->setPosition(Point(startWidth,startHeight));


    /*添加“打开|关闭音效”按钮*/
    _openEffectItem=MenuItemImage::create(
        "SettingSceneImages/openEffectItem_1.png","SettingSceneImages/openEffectItem_2.png");
    _closeEffectItem=MenuItemImage::create(
        "SettingSceneImages/openEffectItem_1.png","SettingSceneImages/openEffectItem_2.png");

    //组合按钮
    auto setEffectMenuToggle=MenuItemToggle::createWithCallback(CC_CALLBACK_1(SettingScene::menuSetEffectCallback,_openEffectItem,_closeEffectItem,NULL);
    setEffectMenuToggle->setPosition(Point(300,400));


    /*添加“打开|关闭血条”按钮*/
    _openHpBarItem=MenuItemImage::create(
        "SettingSceneImages/openHpBarItem_1.png","SettingSceneImages/openHpBarItem_2.png");
    _closeHpBarItem=MenuItemImage::create(
        "SettingSceneImages/openHpBarItem_1.png","SettingSceneImages/openHpBarItem_2.png");
    //组合按钮
    auto setHpBarMenuToggle=MenuItemToggle::createWithCallback(CC_CALLBACK_1(SettingScene::menuSetHpBarCallback,_openHpBarItem,_closeHpBarItem,NULL);
    setHpBarMenuToggle->setPosition(Point(0,0));

    //总菜单
        auto menu=Menu::create(setMusicMenuToggle,setEffectMenuToggle,setHpBarMenuToggle,NULL);
        menu->setPosition(Point(0,0));
        this->addChild(menu,1);

}

首先, 创建两个 MenuItemImage,然后把他们都添加到了 MenuItemToggle 里面。这个类会管理当前应该显示菜单项,同时会在开关元素之间进行一些切换。

注意,当创建 MenuItemImage 的时候,最好不设置回调函数(也可以把回调函数设置成了NULL),而是为 MenuItemToggle 类设置了回调函数。这样当 MenuItemImage 在 MenuItemToggle 中的时候,在 MenuItemImage 上的任何 selector 都不会被调用,而只有 MenuItemToggle的selector会被调用。当然,我们可以很容易地在回调函数里面区分,到底哪个菜单项是可见的。

也就是在MenuItemToggle这一层抽象层上,编写回调函数的时候不需要考虑下一层的具体,而是只是完成它的回调函数


特别注意,坐标设置

我们在创建MenuItemImage项的时候不用设置坐标,而是指定MenuItemToggle的坐标。然后把Toggle添加到Menu里,这里有一个设置坐标的细节。 为了设置坐标方便,一般把Menu坐标设置为Point::ZERO,这样在向Menu添加菜单项的时候菜单项(MenuItemxxx)就可以直接写相对于实际屏幕的坐标了.

猜你在找的Cocos2d-x相关文章