Cocos2d 利用CCProgressTimer 实现自定义游戏血量条

这几天在做自己游戏项目中的血量条,分享下我自己的血量条插件

通过翻查网站,发现COCOS2D已经提供了一个接近效果的封装,CCProgressTimer

首先介绍下CCProgressTimer

它是一个基础进度条,能够支持若干种进度条样式,包括圆形进度条,条形进度条,根据一个百分比属性,实现显示/隐藏进度条的部分,达到图形化显示进度的作用。

优点:

- 继承自CCNode,能共随意的变换大小,旋转角度,并且能够使用CCAction

缺点:

- 无法使用在CCBatchNode,大量使用时会占用不少系统资源。

- 单独使用无法自定义譬如背景,前景等效果。

 

接下来开始动手自给自足,通过结合CCProgressTimer,封装自定义的血量条

我需要的效果:

1- 圈形血条,上端开口,血量在金属槽内流动,能够改变背景/前景

2- 能够控制隐藏/显示

3- 能够随意放大,缩小

 

准备素材

无血量的金属条-healthCircleBackground.png:

Cocos2d 利用CCProgressTimer 实现自定义游戏血量条

血量条-healthCircle.png:

Cocos2d 利用CCProgressTimer 实现自定义游戏血量条

叠加效果预览:

Cocos2d 利用CCProgressTimer 实现自定义游戏血量条

 

实现代码

创建自定义显示插件类ZODisplayPlug

.h实现:

#import "cocos2d.h"



@interface ZODisplayPlug : CCSprite

{

    CCSprite *s_background;

    CCProgressTimer *s_progressTimer;

    CCSprite *s_mask;

}



@property (nonatomic, retain) CCSprite *Background;

@property (nonatomic, retain) CCProgressTimer *ProgressTimer;

@property (nonatomic, retain) CCSprite *Mask;



-(id) initForBatchNodeWithProgressTimer:(NSString*)progressTimer background:(NSString*)background mask:(NSString*)mask;



+(id) displayPlugForBatchNodeWithProgressTimer:(NSString*)progressTimer background:(NSString*)background mask:(NSString*)mask;



@end

.m实现:

#import "ZODisplayPlug.h"

    

@implementation ZODisplayPlug



@synthesize Background = s_background;

@synthesize ProgressTimer = s_progressTimer;

@synthesize Mask = s_mask;



- (id)init

{

    self = [super init];

    if (self) {

        // Initialization code here.

        s_background = nil;

        s_progressTimer = nil;

        s_mask = nil;

    }

    

    return self;

}



- (void)dealloc {

    [s_background release];

    [s_progressTimer release];

    [s_mask release];

    [super dealloc];

}

初始化方法实现:

-(id) initForBatchNodeWithProgressTimer:(NSString*)progressTimer background:(NSString*)background mask:(NSString*)mask;

{

    self = [self init];

    if (self) {

        if (progressTimer) {

            self.ProgressTimer = [CCProgressTimer progressWithSprite:[CCSprite spriteWithSpriteFrameName:[NSString stringWithFormat:@"%@.png",progressTimer]]];//由于我的精灵都是使用CCBatchNodes创建的,也可以换成[CCSprite spriteWithFileName:[NSString stringWithFormat:@"%@.png",progressTimer]]

            self.contentSize = self.ProgressTimer.contentSize;//将进度条的外框设置为血量条的框

            self.ProgressTimer.position = ccp((self.contentSize.width) / 2, (self.contentSize.height) / 2);//将加入的精灵位置设置在血量条外框的中心

            [self addChild:self.ProgressTimer z:0];

        }

        if (background) {

            self.Background = [CCSprite spriteWithSpriteFrameName:[NSString stringWithFormat:@"%@.png",background]];

            self.Background.position = ccp((self.contentSize.width) / 2, (self.contentSize.height) / 2);

            [self addChild:self.Background z:-1];//背景Z坐标在最后

        }

        if (mask) {

            self.Mask = [CCSprite spriteWithSpriteFrameName:[NSString stringWithFormat:@"%@.png",mask]];

            self.Mask.position = ccp((self.contentSize.width) / 2, (self.contentSize.height) / 2);

            [self addChild:self.Mask z:1];//前景Z坐标在最前

        }

    }

    return self;

}



+(id) displayPlugForBatchNodeWithProgressTimer:(NSString*)progressTimer background:(NSString*)background mask:(NSString*)mask;

{

    return [[[self alloc]initForBatchNodeWithProgressTimer:progressTimer background:background mask:mask]autorelease];

}

 

使用血量条

创建一个背景为healthCircleBackground.png,以healthCircle.png为血量的血量条

//在其他类的方法中

[[ZODisplayPlug displayPlugForBatchNodeWithProgressTimer:@"healthCircle" background:@"healthCircleBackground" mask:nil]

 注意,虽然我们整个血量条封装在一个CCSprite中,但是依然有一个CCPregressTimer在Child序列中,而CCBatchNode的使用必须要求Child的所有Chil序列都必须是CCSprite,所以依然无法使用CCBatchNode。

 改变血量条显示的百分比

//在update或者其他方法中

[ZODisplayPlug.ProgressTimer setPercentage:50];

显示效果:

Cocos2d 利用CCProgressTimer 实现自定义游戏血量条

 至此,一个环形血量条完成了。

 

完成之后

我将会陆续更新我对自定义血量条的修改

你可能感兴趣的:(progress)