Cocos2dx2.2.1中单选按钮的实现

背景

最近做一个学长给的任务,里面需要单选按钮的控件。不知道是我没好好找还是什么原因,cocos2dx中好像没有提供(我总是觉得它应该有这类简单控件)。

想法

单选按钮组成:
两个CcmenuItemToggle类型的按钮作为单选按钮的基本组成(至少两个按钮才能称为‘单选’吧)

实现

下面是我生成单选按钮的方法:

/*checked 是用来设置图片的顺序,即被选中和没有被选中状态的图片 s_bnRing_normal[index]和s_bnRing_selected[index] 是我zai Resourse.h资源文件中定义的char* 数组,里面保存了normal和selected状态的按钮图片,方便批量生成多个toggle*/
Ccmenu* ClockSetting :: toggleMenuCreate_ring(int index,int isChecked)
{
    Ccmenu* toggleMenu = Ccmenu::create();
    CcmenuItemImage* onItemmenu = CcmenuItemImage::create(s_bnRing_selected[index],s_bnRing_selected[index],this,menu_selector(ClockSetting::menuCallBack_ring_items));
    //onItemmenu->setopacity(170);
    CcmenuItemImage* offItemmenu = CcmenuItemImage::create(s_bnRing_normal[index],s_bnRing_normal[index],menu_selector(ClockSetting::menuCallBack_ring_items));
    //offItemmenu->setopacity(170); 
    CcmenuItemToggle *toggleItem;
    if(isChecked == 1)
        toggleItem = CcmenuItemToggle::createWithTarget(this,menu_selector(ClockSetting::menuCallBack_ring_items),onItemmenu,offItemmenu,NULL);
    else
        toggleItem = CcmenuItemToggle::createWithTarget(this,NULL);

    toggleItem->setScale(1.5f);
    toggleItem->setAnchorPoint(ccp(0.5f,1.0f));
    toggleMenu->addChild(toggleItem,0,index);
//这里设置tag对单选功能实现是必须的
    toggleMenu->setTag(index);
    return toggleMenu;
}

在成员变量中我定义了
int ring_tempint ring
这两个变量的作用是

  • 初始化界面的时候,ring来保存从存储数据文件中获取的,这个单选按钮控制的功能(例如一个闹钟,ring = 0代表静音,ring=1代表震动)。ring_temp是用来在来回选择toggle时记录所选功能的。
  • 在退出功能设置界面时,用户有两个选项,一是保存所更改的设置(这时候需要保存的是ring_temp),二是不保存退出(这时候保存的是ring,因为ring除了被初始化的时候不能被改变)。

  • 接下来是实现单选的逻辑
void ClockSetting::menuCallBack_ring_items(CCObject* pSender)
{
    do
    {
        //这里的前两行是用tag获取toggle按钮的父节点的,生成好的toggle需要放到它的父节点中显示
        CCSprite* background = (CCSprite*)getChildByTag(tag_ring_popuplayer_background);
        CCSprite* rect = (CCSprite*)background->getChildByTag(tag_ring_popuplayer_rect);
        Ccmenu* items = (Ccmenu*)pSender;   
        Ccmenu* toggle[2];

        CCSize whitRectBackgroundSize = rect->getContentSize();
        float hight = whitRectBackgroundSize.height/8;
        //获取用户点击是哪个按钮
        lastRing = ring_temp;
        //如果相等,则表示是在重复点击同一个按钮
        if(lastRing == items->getTag())
        {

            if(lastRing == 0)
            {
                //去除被点击的按钮
                rect->removeChildByTag(tag_ring_popuplayer_toggle_1);
                //用于toggle的特性就是点一次换一次图片,所以要保证按钮状态不变,需要重新生成
                toggle[0] = toggleMenuCreate_ring(0,1);
                toggle[0]->setTag(0);   
                toggle[0]->setAnchorPoint(ccp(0.0f,0.5f));
                //这里是位置的设置,具体情况具体设置
                toggle[0]->setPosition(ccp(whitRectBackgroundSize.width/3-40,hight*6-4));
                rect->addChild(toggle[0],tag_ring_popuplayer_toggle_1);
            }
            else
            {
                rect->removeChildByTag(tag_ring_popuplayer_toggle_2);
                toggle[1] = toggleMenuCreate_ring(1,1);
                toggle[1]->setTag(1);   
                toggle[1]->setAnchorPoint(ccp(0.0f,0.5f));
                //这里是位置的设置,具体情况具体设置
                toggle[1]->setPosition(ccp(whitRectBackgroundSize.width/3-40,hight*4-4));
                rect->addChild(toggle[0],tag_ring_popuplayer_toggle_2);
            }
            //跳出do-while
            break;
        }
        cclOG("menuCallBack_ring_items");
        //和上一次点击的按钮不是同一个,保存这次点击的tag
        lastRing = items->getTag();

        //全部移除
        rect->removeChildByTag(tag_ring_popuplayer_toggle_1);
        rect->removeChildByTag(tag_ring_popuplayer_toggle_2);
        Ccmenu* t2 = (Ccmenu*)rect->getChildByTag(tag_ring_popuplayer_toggle_2);

        if(ring_temp == 1)
        {
            //改变ring_temp所代表的标示,标示用户选择了新的功能
            ring_temp =0;
            toggle[0] = toggleMenuCreate_ring(0,1);
            toggle[1] = toggleMenuCreate_ring(1,0);
            CCSize toggleSize = toggle[0]->getContentSize();
            for(int i=0;i<2;i++)
            {
                toggle[i]->setTag(i);   
                toggle[i]->setAnchorPoint(ccp(0.0f,0.5f));
                //这里是位置的设置,具体情况具体设置
                toggle[i]->setPosition(ccp(whitRectBackgroundSize.width/3-40,hight*(6-2*i)-4));
            }
            rect->addChild(toggle[0],tag_ring_popuplayer_toggle_1);
            rect->addChild(toggle[1],tag_ring_popuplayer_toggle_2);
        }
        else
        {
            //gee
            ring_temp =1;
            Ccmenu* toggle[2];
            toggle[0] = toggleMenuCreate_ring(0,0);
            toggle[1] = toggleMenuCreate_ring(1,1);
            CCSize toggleSize = toggle[0]->getContentSize();
            for(int i=0;i<2;i++)
            {
    // toggle[i]->setTag(i); 
                toggle[i]->setAnchorPoint(ccp(0.0f,0.5f));
                toggle[i]->setPosition(ccp(whitRectBackgroundSize.width/3-40,tag_ring_popuplayer_toggle_2);
        }
    }while(0);
}

基本就是这样。
这篇博客是我去年学cocos2dx做一个小应用的时候写的,原文在这里。

Cocos2dx2.2.1中单选按钮的实现的更多相关文章

  1. HTML5 input新增type属性color颜色拾取器的实例代码

    type 属性规定 input 元素的类型。本文较详细的给大家介绍了HTML5 input新增type属性color颜色拾取器的实例代码,感兴趣的朋友跟随脚本之家小编一起看看吧

  2. amazeui模态框弹出后立马消失并刷新页面

    这篇文章主要介绍了amazeui模态框弹出后立马消失并刷新页面,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  3. 移动HTML5前端框架—MUI的使用

    这篇文章主要介绍了移动HTML5前端框架—MUI的使用的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  4. 详解Canvas实用库Fabric.js使用手册

    这篇文章主要介绍了详解Canvas实用库Fabric.js使用手册的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  5. 【HTML5】3D模型--百行代码实现旋转立体魔方实例

    本篇文章主要介绍【HTML5】3D模型--百行代码实现旋转立体魔方实例,具有一定的参考价值,有需要的可以了解一下。

  6. H5 canvas实现贪吃蛇小游戏

    本篇文章主要介绍了H5 canvas实现贪吃蛇小游戏,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  7. AmazeUI 模态窗口的实现代码

    这篇文章主要介绍了AmazeUI 模态窗口的实现代码,代码简单易懂,非常不错,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. ios – 如何更改UINavigationBar底部边框的颜色?

    我阅读了许多主题,但没有一个在最新版本的Swift的清晰,一致的答案中解决了这个问题.例如,thisquestion的最佳答案表明UINavigationBar.appearance().setShadowImage().但是,最新版本的swift中不存在这样的方法.我不想隐藏底部边框.我只是想改变颜色.另外,能够改变高度会很棒,但我知道我在一个问题上问得太多了.编辑:我创建了一个2×1像素图像并

  9. ios – UIPopoverController出现在错误的位置

    所以我花了一些时间寻找答案,但到目前为止还没有找到任何答案.我正在尝试从UIInputAccessoryView上的按钮呈现弹出窗口.UIBarButtonItem我想显示popover来自定制视图,所以我可以使用图像.我创建这样的按钮:当需要显示popover时,我这样做:但我得到的是:弹出窗口看起来很好,但它应该出现在第一个按钮上时出现在第二个按钮上.然后我发现了这个问题:UIBarButto

  10. ios – 关闭UIBarButtonItem上的突出显示

    我正在尝试使用UIBarButtonItem在我的UIToolbar上添加标题.我使用简单的风格,看起来很好,但我似乎无法让它停止突出显示触摸.“突出显示时触摸”选项不适用于条形按钮项目.有没有快速简便的方法来做到这一点?

随机推荐

  1. 【cocos2d-x 3.x 学习笔记】对象内存管理

    Cocos2d-x的内存管理cocos2d-x中使用的是上面的引用计数来管理内存,但是又增加了一些自己的特色。cocos2d-x中通过Ref类来实现引用计数,所有需要实现内存自动回收的类都应该继承自Ref类。下面是Ref类的定义:在cocos2d-x中创建对象通常有两种方式:这两中方式的差异可以参见我另一篇博文“对象创建方式讨论”。在cocos2d-x中提倡使用第二种方式,为了避免误用第一种方式,一般将构造函数设为protected或private。参考资料:[1]cocos2d-x高级开发教程2.3节[

  2. 利用cocos2dx 3.2开发消灭星星六如何在cocos2dx中显示中文

    由于编码的不同,在cocos2dx中的Label控件中如果放入中文字,往往会出现乱码。为了方便使用,我把这个从文档中获取中文字的方法放在一个头文件里面Chinese.h这里的tex_vec是cocos2dx提供的一个保存文档内容的一个容器。这里给出ChineseWords,xml的格式再看看ChineseWord的实现Chinese.cpp就这样,以后在需要用到中文字的地方,就先include这个头文件然后调用ChineseWord函数,获取一串中文字符串。

  3. 利用cocos2dx 3.2开发消灭星星七关于星星的算法

    在前面,我们已经在GameLayer中利用随机数初始化了一个StarMatrix,如果还不知道怎么创建星星矩阵请回去看看而且我们也讲了整个游戏的触摸事件的派发了。

  4. cocos2dx3.x 新手打包APK注意事项!

    这个在编译的时候就可以发现了比较好弄这只是我遇到的,其他的以后遇到再补充吧。。。以前被这两个问题坑了好久

  5. 利用cocos2dx 3.2开发消灭星星八游戏的结束判断与数据控制

    如果你看完之前的,那么你基本已经拥有一个消灭星星游戏的雏形。开始把剩下的两两互不相连的星星消去。那么如何判断是GameOver还是进入下一关呢。。其实游戏数据贯穿整个游戏,包括星星消除的时候要加到获得分数上,消去剩下两两不相连的星星的时候的加分政策等,因此如果前面没有做这一块的,最好回去搞一搞。

  6. 利用cocos2dx 3.2开发消灭星星九为游戏添加一些特效

    needClear是一个flag,当游戏判断不能再继续后,这个flag变为true,开始消除剩下的星星clearSumTime是一个累加器ONE_CLEAR_TIME就是每颗星星消除的时间2.连击加分信息一般消除一次星星都会有连击信息和加多少分的信息。其实这些combo标签就是一张图片,也是通过控制其属性或者runAction来实现。源码ComboEffect.hComboEffect.cpp4.消除星星粒子效果消除星星时,为了实现星星爆裂散落的效果,使用了cocos2d提供的粒子特效引擎对于粒子特效不了

  7. 02 Cocos2D-x引擎win7环境搭建及创建项目

    官网有搭建的文章,直接转载记录。环境搭建:本文介绍如何搭建Cocos2d-x3.2版本的开发环境。项目创建:一、通过命令创建项目前面搭建好环境后,怎样创建自己的Cocos2d-x项目呢?先来看看Cocos2d-x3.2的目录吧这就是Cocos2d-x3.2的目录。输入cocosnew项目名–p包名–lcpp–d路径回车就创建成功了例如:成功后,找到这个项目打开proj.win32目录下的Hello.slnF5成功了。

  8. 利用cocos2dx 3.2开发消灭星星十为游戏添加音效项目源码分享

    一个游戏,声音也是非常的重要,其实cocos2dx里面的简单音效引擎的使用是非常简单的。我这里只不过是用一个类对所有的音效进行管理罢了。Audio.hAudio.cpp好了,本系列教程到此结束,第一次写教程如有不对请见谅或指教,谢谢大家。最后附上整个项目的源代码点击打开链接

  9. 03 Helloworld

    程序都有一个入口点,在C++就是main函数了,打开main.cpp,代码如下:123456789101112131415161718#include"main.h"#include"AppDelegate.h"#include"cocos2d.h"USING_NS_CC;intAPIENTRY_tWinMain{UNREFERENCED_ParaMETER;UNREFERENCED_ParaMETER;//createtheapplicationinstanceAppDelegateapp;return

  10. MenuItemImage*图标菜单创建注意事项

    学习cocos2dx,看的是cocos2d-x3.x手游开发实例详解,这本书错误一大把,本着探索求知勇于发现错误改正错误的精神,我跟着书上的例子一起调试,当学习到场景切换这个小节的时候,出了个错误,卡了我好几个小时。

返回
顶部