CCMenuItemToggle实现选中的效果

本文介绍了一个基于Cocos2d-x的小程序中实现颜色选择功能的方法。通过使用CCMenuItemToggle组件,可以创建一个包含多种颜色选项的复选框。文中详细展示了如何通过代码设置不同状态下的图片展示及切换逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近自己在做的一个小程序想加上一个选择颜色的功能。

大概的设想呢就是一共有七种颜色可以选择,最少选择两种,最多都选。大概就是类似于一个复选框的东西吧。


初步的实现呢就是每种颜色的选择就是一个CCMenuItemToggle,选中状态是一个图片,非选中状态是另一个图片。

大概的代码呢如下:


*.h

@interface Layer :CCLayer

}


@property(retain,nonatomic)CCMenuItemToggle * colorMenuToggle;

+(id)sense;

@end


*.m

int colorIndex;

@implement Layer

@synthesize colorMenuToggle;

+(id)sense

{

    CCScene * scene = [CCScene init];

    id layer = [Layer node];

    [scene addChild:layer];

    return sense;

}

-(id)init

{

    if(self =[super init])

    {

        

        CCMenuItemImage * choiceButton = 

        [CCMenuItemImageitemFromNormalImage:@"choice.png"selectedImage:nil target:nilselector:nil];

        CCMenuItemImage * choiceButton2 = 

        [CCMenuItemImageitemFromNormalImage:@"choice2.png"selectedImage:nil target:nilselector:nil];

        self.colorMenuToggle

        [CCMenuItemToggleitemWithTarget:selfselector:@selector(choice:)items:choiceButton,choiceButton2,nil];

        

        CCMenu *toggleMenu = [CCMenumenuWithItems:self.colorMenuToggle,nil];

        toggleMenu.position =ccp(100, 220);

        [selfaddChild:toggleMenu];

    }

    return self;

}


-(void)choice:(id)sender

{

    if(colorIndex==1)

    {

        [self.colorMenuTogglesetSelectedIndex:0];

       colorIndex = 0;

    }

   else

    {

        [self.colorMenuTogglesetSelectedIndex:1];

       colorIndex = 1;

    }

}


@end


CCMenuItemToggle的items有几个index才有几个,例如items就有一个那index只能等于0,如果是两个item,那index有0跟1两值,以此类推。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值