菜单是我们在开发中经常用到的元素,cocos2d-x中的菜单基本上是分装了文本类和精灵类,代码注释有详细的说明,看代码吧!
bool HelloWorld::init()
{
bool bRet = false;
do
{
CC_BREAK_IF(! CCLayer::init());
CCLabelTTF * ttf = CCLabelTTF::create("cocos2d","Arial",24);
//没有设置坐标,默认放到CCMenu层的中间,第二个参数是事件处理函数属于的类,第三个参数就是调用的函数
//menu_selector菜单选择器
CCMenuItemLabel * labelMenu = CCMenuItemLabel::create(ttf,this,menu_selector(HelloWorld::show));
//可以提前修改字体和大小,否则使用默认的
CCMenuItemFont::setFontName("Arial");
CCMenuItemFont::setFontSize(50);
//内部实现是创建出一个CCLabelTTF,然后用CCLabelTTF创建CCMenuItemLabel
CCMenuItemFont * fontMenu = CCMenuItemFont::create("cocos2d",this,menu_selector(HelloWorld::show));
//内部实现是创建出一个CCLabelAtlas,然后用CCLabelAtlas创建CCMenuItemLabel
CCMenuItemAtlasFont * atlasMenu = CCMenuItemAtlasFont::create("2014/2/12","fps_images.png",
12,32,'.',this,menu_selector(HelloWorld::show));
//内部实现是创建一个CCSprite,用CCSprite创建CCMenuItemSprite
CCMenuItemImage * imgMenu = CCMenuItemImage::create("CloseNormal.png","CloseSelected.png",this,
menu_selector(HelloWorld::show));
CCMenuItemFont * font1 = CCMenuItemFont::create("start");
CCMenuItemFont * font2 = CCMenuItemFont::create("stop");
CCMenuItemToggle * toggle = CCMenuItemToggle::createWithTarget(this,menu_selector(HelloWorld::show2),
font1,font2,NULL);
//CCMenu就是一个特殊的CCLayer,只是这个层中只能放CCMenuItem和CCMenuItem的子类
//在这个层中,可以为CCMenuItem进行布局,因为是层所以坐标当然默认是(0,0),而且是以左下角点占据坐标位置的
CCMenu * menu = CCMenu::create(labelMenu,fontMenu,imgMenu,toggle,NULL);
//为菜单项进行布局,否则就叠加在一起了
menu->alignItemsHorizontallyWithPadding(10);
this->addChild(menu);
bRet = true;
} while (0);
return bRet;
}
事件激活函数如下,不要忘记在头文件中声明一下。
void HelloWorld::show(CCObject * pSender)
{
CCLog("label menu!");
}
void HelloWorld::show2(CCObject * sender)
{
CCMenuItemToggle * toggle = (CCMenuItemToggle*)sender;
if(toggle->getSelectedIndex() == 0)
{
CCLog("start");
}
else if(toggle->getSelectedIndex() == 1)
{
CCLog("stop");
}
}
您可能感兴趣的文章:Cocos2d-x UI开发之文本类使用实例