【Cocosd2d-x CCMenu菜单之二】
菜单项CCMenuItem是一个基类。 子类CCMenuItemFont、CCMenuItemLabel、CCMenuItemSprite、CCMenuItemToggle可增加CCMenu中形成菜单。
程序代码:
bool HelloWorld::init()
{ if ( !CCLayer::init() )
{
return false;
} CCSize visibleSize = CCDirector::sharedDirector()->getVisibleSize();
CCPoint origin = CCDirector::sharedDirector()->getVisibleOrigin(); CCMenuItemImage *pCloseItem = CCMenuItemImage::create(
"CloseNormal.png",
"CloseSelected.png",
this,
menu_selector(HelloWorld::menuCloseCallback)); pCloseItem->setPosition(ccp(origin.x + visibleSize.width - pCloseItem->getContentSize().width/2 ,
origin.y + pCloseItem->getContentSize().height/2)); // create menu, it's an autorelease object
CCMenu* pMenu = CCMenu::create(pCloseItem, NULL);
pMenu->setPosition(CCPointZero);
this->addChild(pMenu, 1); //add your code...
//使用字体定义菜单项,包含 CCMenuItemAtlasFont, CCMenuItemFont 两种方式,CCMenuItemFont通过设置字体名称来设置字体。
CCMenuItemFont::setFontSize(30); //字号
CCMenuItemFont::setFontName("Courier New");//字体
CCMenuItemFont *item = CCMenuItemFont::create("--- Go Back ---", this, menu_selector(HelloWorld::menuItemFontcall));//參数1:文字内容。參数2:运行回调函数的目标类。參数3:按下触发的回调函数
//item->setPosition(ccp(visibleSize.width/2,100)); //通过字体配置PNG文件的 CCLabelAtlas
CCLabelAtlas *atlasfont = CCLabelAtlas::create("0123456789", "labelatlas.png", 16, 24, '.');//參数顺序:文字内容,图片,单个文字宽,单个文字高,默认显示字符
CCMenuItemLabel *item1 = CCMenuItemLabel::create(atlasfont, this, menu_selector(HelloWorld::menuItemFontcall2));//參数顺序:文字渲染类,运行回调函数的目标类,按下触发的回调函数
//item1->setPosition(ccp(visibleSize.width/2,400)); //精灵菜单项
CCSprite *spriteNormal = CCSprite::create("menuitemsprite.png", CCRectMake(0,23*2,115,23));
CCSprite *spriteSelected = CCSprite::create("menuitemsprite.png", CCRectMake(0,23*1,115,23));
CCSprite *spriteDisabled = CCSprite::create("menuitemsprite.png", CCRectMake(0,23*0,115,23)); CCMenuItemSprite* item3 = CCMenuItemSprite::create(spriteNormal, spriteSelected, spriteDisabled, this, menu_selector(HelloWorld::menuCallback3));//參数:3种菜单状态及回调函数
//item3->setPosition(ccp(visibleSize.width/2,300)); //通过字体配置FNT类型文件的CCLabelBMFont
CCLabelBMFont* label = CCLabelBMFont::create("Enable AtlasItem", "bitmapFontTest3.fnt");
CCMenuItemLabel* item4 = CCMenuItemLabel::create(label, this, menu_selector(HelloWorld::menuCallback4) );
//item4->setPosition(ccp(visibleSize.width/2+50,250)); //触发器菜单项,能够将不论什么菜单项传递进去
CCMenuItemToggle *toggle = CCMenuItemToggle::createWithTarget( this,
menu_selector(HelloWorld::menuCallback5),
CCMenuItemFont::create("On"),
CCMenuItemFont::create("Off"),
NULL);
//toggle->setPosition(ccp(visibleSize.width/2+100, 150)); CCMenu *menu = CCMenu::create(item, item1, item3, item4, toggle, NULL);
menu->alignItemsVertically(); CCSize s = CCDirector::sharedDirector()->getWinSize(); int i=0;
CCNode* child;
CCArray * pArray = menu->getChildren(); //获取menu全部节点(菜单项)
CCObject* pObject = NULL;
CCARRAY_FOREACH(pArray, pObject)
{
if(pObject == NULL)
break; child = (CCNode*)pObject; CCPoint dstPoint = child->getPosition();//获取每一个节点位置
int offset = (int) (s.width/2 + 50);
if( i % 2 == 0)
offset = -offset; child->setPosition( ccp( dstPoint.x + offset, dstPoint.y) );//设置菜单项初始位置
child->runAction(
CCEaseElasticOut::create(CCMoveBy::create(2, ccp(dstPoint.x - offset,0)), 0.35f) //从初始位置移动新的位置。有振幅效果
);
i++;
} menu->setPosition(ccp(s.width/2, s.height/2));
this->addChild(menu); return true; } void HelloWorld::menuItemFontcall(CCObject* pSender)
{
CCLOG("menuItemFontcall...");
} void HelloWorld::menuItemFontcall2(CCObject* pSender)
{
CCLOG("menuItemFontcall2...");
}
void HelloWorld::menuCallback3(CCObject* pSender)
{
CCLOG("menuCallback3...");
}
void HelloWorld::menuCallback4(CCObject* pSender)
{
CCLOG("menuCallback4...");
}
void HelloWorld::menuCallback5(CCObject* pSender)
{
CCLOG("menuCallback5...");
}
【Cocosd2d-x CCMenu菜单之二】的更多相关文章
- WIN 下的超动态菜单(二)用法
WIN 下的超动态菜单(一)简介 WIN 下的超动态菜单(二)用法 WIN 下的超动态菜单(三)代码 作者:黄山松,发表于博客园:http://www.cnblogs.com/tomview/ ...
- Cocos2d-x学习笔记(10)(CCMenu菜单)
1.CCMenu创建方式 CCMenu* menu = CCMenu::create(cocos2d::CCMenuItem* item,--)參数为CCMenuItem菜单项的对象可变參数列表 2. ...
- SharePoint 2013 自定义扩展菜单(二)
接博文<SharePoint 2013 自定义扩展菜单>,多加了几个例子,方便大家理解. 例七 列表设置菜单扩展(listedit.aspx) 扩展效果 XML描述 <CustomA ...
- SharePoint开发 - 自定义导航菜单(二)母版页的菜单应用
博客地址 http://blog.csdn.net/foxdave 接上篇点击打开链接 本篇叙述在母版页中应用之前的配置信息生成菜单,主要涉及到母版页的自定义,并应用了第三方控件库DevExpress ...
- 菜单之二:使用xml文件定义菜单
参考<疯狂android讲义>2.10节 P174,参见归档project:XmlMenuDemo.zip 一般推荐使用XML文件定义菜单. 基本步骤如下: 1.定义布局文件 为简单显示原 ...
- 再造 “手机QQ” 侧滑菜单(二)——高仿左视图
代码示例:https://github.com/johnlui/SwiftSideslipLikeQQ 本篇文章中,我们将一起使用 Auto Layout 高仿手Q的左侧视图,力争达成从布局到动画的全 ...
- 菜单之二:使用xml文件定义菜单 分类: H1_ANDROID 2013-11-03 09:39 1038人阅读 评论(0) 收藏
参考<疯狂android讲义>2.10节 P174,参见归档project:XmlMenuDemo.zip 一般推荐使用XML文件定义菜单. 基本步骤如下: 1.定义布局文件 为简单显示原 ...
- angular复选框式js树形菜单(二)
删除(过滤)树形结构某一个子节点: function filterTreeData(treeData){ angular.forEach(treeData,function(item){ if (it ...
- Android 开发笔记(二)菜单设计
菜单设计一 // 创建菜单 public boolean onCreateOptionsMenu(Menu menu) { menu.add(0, 0, 0, "关于"); men ...
随机推荐
- electron 安装使用
1.安装 node.js 链接:http://pan.baidu.com/s/1o7W7BIy 密码:y6od 一路next 我安装在F:\Program Files\node.js下 2.检查nod ...
- cp2102通过GPIO连接树莓派
此博客不在更新,我的博客新地址:www.liuquanhao.com ----------------------------------------------------------------- ...
- linux题目整理(一)
1.Linux如何挂载windows下的共享目录? mount.cifs /IP地址/server/ /mnt/server -O user=administrator password=yourpa ...
- Android 中带有进度条效果的按钮(Button)
安卓中带有进度条效果的按钮,如下图: 1.布局文件如下activity_main.xml <RelativeLayout xmlns:android="http://schemas.a ...
- MVC中Model和model的区别和用户
MVC中Model和model的区别,它们应该怎么用呢? 使用@model关键字可以定义一个Action里所对应的一个模型(经常可以叫他实体类). MVC的第一个字母M是Model,承载着View层和 ...
- EL的函数与标签
1 什么EL函数库 EL函数库是由第三方对EL的扩展,我们现在学习的EL函数库是由JSTL添加的.下面我们会学习JSTL标签库. EL函数库就是定义一些有返回值的静态方法.然后通过EL语言来调用它们! ...
- 离别在须臾——AFO
始于 2016-12-25 终于 2017-11-30 一开始就陷入了颓废的坑,然后,直至 2017 年暑假,颓废的气息一发不可收拾, 从 Q_fight 到 aoqi_baitian ,从 大主宰 ...
- iOS UI、Xcode、调试、代码等常见问题总汇(持续更新中)
以前比较懒,遇到问题解决了就完事了,有些问题再次遇到时忘记了当初是怎么解决的,又要查各种资料来解决.好记忆不如烂笔头,不管简单还是复杂都记一下吧,所以决定写一篇常见问题总结,方便以后查阅.现在有点忙, ...
- 什么是IIS并发连接数
http://blog.csdn.net/leftfist/article/details/38407223 https://wk.baidu.com/view/2962d073f242336c1e ...
- GTK+重拾--09 GTK+中的组件(一)
(一):写在前面 在这篇文章中主要介绍了GTK+程序中的各种构件,这是解说构件的第一个部分,另外一部分将在下一个小节中讲到. 构件是建立一个GUI程序的基础.在GTK+的长期发展过程中.一些特定的构件 ...