实例介绍Cocos2d-x精灵菜单和图片菜单
精灵菜单类是MenuItemSprite,图片菜单类是MenuItemImage。由于MenuItemImage继承于MenuItemSprite,所以图片菜单也属于精灵菜单。为什么叫精灵菜单呢?那是因为这些菜单项具有精灵的特点,我们可以让精灵动起来,具体使用时候是把一个精灵放置到菜单中作为菜单项。
精灵菜单类MenuItemSprite,它的其中一个创建函数create定义如下:
- <span style="font-size:14px;">static MenuItemSprite* create ( Node * normalSprite, //菜单项正常显示时候的精灵
- Node * selectedSprite, //选择菜单项时候的精灵
- Node * disabledSprite, //菜单项禁用时候的精灵
- const ccMenuCallback & callback //菜单操作的回调函数指针
- )</span>
使用MenuItemSprite比较麻烦,在创建MenuItemSprite之前要先创建三种状态时候的精灵(即normalSprite、selectedSprite和disabledSprite)。MenuItemSprite还有一些create函数,在这些函数中可以省略disabledSprite参数。
如果精灵是由图片构成的,我们可以使用图片菜单MenuItemImage实现与精灵菜单同样的效果。MenuItemImage类的其中一个创建函数create定义如下:
- <span style="font-size:14px;">static MenuItemImage* create ( const std::string & normalImage, //菜单项正常显示时候的图片
- const std::string & selectedImage, //选择菜单项时候的图片
- const std::string & disabledImage, //菜单项禁用时候的图片
- const ccMenuCallback & callback //菜单操作的回调函数指针
- )</span>
MenuItemImage还有一些create函数,在这些函数中可以省略disabledImage参数。
我们通过一个实例介绍一下精灵菜单和图片菜单的使用,这个实例如下图所示。
下面我们看看HelloWorldScene.cpp中init函数如下:
- <span style="font-size:14px;">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;
- }</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代码如下:
- 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代码如下:
- <pre code_snippet_id="340364" snippet_file_name="blog_20140512_5_4431376" name="code" class="html">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);
- }
- … …
- }</pre>
我们需要在第①行添加glview->setFrameSize(1136, 640)代码。
实例介绍Cocos2d-x精灵菜单和图片菜单的更多相关文章
- Cocos2d-JS中的精灵菜单和图片菜单
精灵菜单的菜单项类是cc.MenuItemSprite,图片菜单的菜单项类是cc.MenuItemImage.由于cc.MenuItemImage继承于cc.MenuItemSprite,所以图片菜单 ...
- 实例介绍Cocos2d-x开关菜单
开关菜单是MenuItemToggle类实现的,它是一种可以进行两种状态切换的菜单.它可以通过下面的函数创建: static MenuItemToggle*createWithCallback ( ...
- 【转】Android实例剖析笔记(二)--用实例讲解Andriod的开发过程,以NotesList为实例介绍Android的菜单机制
原文网址:http://kb.cnblogs.com/page/78304/ 简介 android提供了三种菜单类型,分别为options menu,context menu,sub menu. op ...
- Cocos2d-x开发实例介绍帧动画使用
下面我们通过一个实例介绍一下帧动画的使用,这个实例如下图所示,点击Go按钮开始播放动画,这时候播放按钮标题变为Stop,点击Stop按钮可以停止播放动画. 下面我们再看看具体的程序代码,首先看一下看H ...
- Cocos2d-x开发实例介绍特效演示
下面我们通过一个实例介绍几个特效的使用,这个实例下图所示,下图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜单 ...
- Cocos2d-x中__Dictionary容器以及实例介绍
__Dictionary类在Cocos2d-x 2.x时代它就是CCDictionary类,它是模仿Objective-C中的NSDictionary类而设计的,通过引用计数管理内存.__Dictio ...
- Cocos2d-x中__Array容器以及实例介绍
__Array类在Cocos2d-x 2.x时代它就是CCArray类.它是模仿Objective-C中的NSArray类而设计的,通过引用计数管理内存.__Array继承于Ref类,因此它所能容纳的 ...
- 实例介绍Cocos2d-x中Box2D物理引擎:HelloBox2D
我们通过一个实例介绍一下,在Cocos2d-x 3.x中使用Box2D物理引擎的开发过程,熟悉这些API的使用.这个实例运行后的场景如图所示,当场景启动后,玩家可以触摸点击屏幕,每次触摸时候,就会在触 ...
- 实例介绍Cocos2d-x物理引擎:碰撞检测
碰撞检测是使用物理引擎的一个重要目的,使用物理引擎可以进行精确的碰撞检测,而且执行的效率也很高.在Cocos2d-x 3.x中使用事件派发机制管理碰撞事件,EventListenerPhysicsCo ...
随机推荐
- (高精度运算4.7.26)POJ 1220 NUMBER BASE CONVERSION(高精度数的任意进制的转换——方法:ba1----->10进制----->ba2)
package com.njupt.acm; import java.math.BigInteger; import java.util.Scanner; public class POJ_1220_ ...
- mysql中自己定义函数编程
语法: 新建: Create function function_name(參数列表)returns返回值类型 函数体 函数名,应该合法的标识符,而且不应该与已有的keyword冲突. 一个函数应该属 ...
- 【原创】PostSharp入门笔记
最近写了一个抓取软件,用户反映软件偶尔会抛异常: 由于当时写代码时没有注意异常处理,大部分方法都没有写try…catch…finally的语句,所以很难找出异常是出在哪个地方,难道要为所有方法加上tr ...
- centos 安装git server
1.yum install lrzsz wget git 2.安装gitosis:gitosis为Git用户权限管理系统,通过管理服务端的/home/git/.ssh/authorized_key文件 ...
- [转]使用 PIVOT 和 UNPIVOT
可以使用 PIVOT 和 UNPIVOT 关系运算符将表值表达式更改为另一个表.PIVOT 通过将表达式某一列中的唯一值转换为输出中的多个列来旋转表值表达式,并在必要时对最终输出中所需的任何其余列值执 ...
- windows 8.1 在硬盘上创建扩展分区
管理员-命令提示符-> diskpart -->进入分区工具. list disk -->显示电脑连接磁盘数. select disk * -->选择编号为*的 ...
- C. Tavas and Karafs 二分查找+贪心
C. Tavas and Karafs #include <iostream> #include <cstdio> #include <cstring> #incl ...
- Boost.Foreach
BOOST_FOREACH简化了C++的循环遍历序列元素. 支持的序列类型:Boost.Range识别的序列 STL容器 数组 Null-terminated String std::pair of ...
- UICollectionView 简单应用和实际操作
1.网格视图 UICollectionView 网格布局 UICollectionViewFlowLayout系统图自带网格布局 系统自带的网格布局 UICollectionViewFl ...
- C#中常用的排序算法的时间复杂度和空间复杂度
常用的排序算法的时间复杂度和空间复杂度 常用的排序算法的时间复杂度和空间复杂度 排序法 最差时间分析 平均时间复杂度 稳定度 空间复杂度 冒泡排序 O(n2) O(n2) 稳定 O(1) 快速排序 ...