`

Cocos2D Coloring Sprites

 
阅读更多
#import "cocos2d.h"
#import "Recipe.h"

enum {
	TAG_FADE_TO_BLACK = 0,
	TAG_FADE_TO_WHITE = 1,
	TAG_FADE_SPRITE = 2,
	TAG_MOUNTAIN_BG = 3,
	TAG_SUN_BG = 4,
	TAG_GOOD_SAMURAI = 5,
	TAG_BAD_SAMURAI = 6,
	TAG_GROUND_GRADIENT = 7,
	TAG_RED_GRADIENT = 8
};

//Interface
@interface Ch1_ColoringSprites : Recipe
{
}

-(CCLayer*) runRecipe;
-(void) initButtons;
-(void) fadeToBlackCallback:(id)sender;
-(void) fadeToWhiteCallback:(id)sender;
-(void) drawColoredSpriteAt:(CGPoint)position withRect:(CGRect)rect withColor:(ccColor3B)color withZ:(float)z;
-(void) glowAt:(CGPoint)position withScale:(CGSize)size withColor:(ccColor3B)color withRotation:(float)rotation withSprite:(CCSprite*)sprite;

@end



//Implementation
@implementation Ch1_ColoringSprites

-(CCLayer*) runRecipe {
	[self initButtons];
		
	//The Fade Scene Sprite
	CCSprite *fadeSprite = [CCSprite spriteWithFile:@"blank.png"];
	[fadeSprite setOpacity:0];
	[fadeSprite setPosition:ccp(240,160)];
	[fadeSprite setTextureRect:CGRectMake(0,0,480,320)];
	[self addChild:fadeSprite z:3 tag:TAG_FADE_SPRITE];
	
	//Draw the sky using blank.png
	[self drawColoredSpriteAt:ccp(240,190) withRect:CGRectMake(0,0,480,260) withColor:ccc3(150,200,200) withZ:0];
	
	//Draw the sun
	CCSprite *sun = [CCSprite spriteWithFile:@"fire.png"];
	[sun setPosition:ccp(50,230)];
	[sun setScale:3.0f];
	[sun setColor:ccc3(255,255,0)];
	[self addChild:sun z:0 tag:TAG_SUN_BG];	
	
	//Draw some mountains in the background
	CCSprite *mountains = [CCSprite spriteWithFile:@"mountains.png"];
	[mountains setPosition:ccp(250,200)];
	[mountains setScale:0.6f];
	[self addChild:mountains z:0 tag:TAG_MOUNTAIN_BG];
	
	//Add a gradient below the mountains
	CCLayerGradient *groundGradient = [CCLayerGradient layerWithColor:ccc4(61,33,62,255) fadingTo:ccc4(65,89,54,255) alongVector:ccp(0,-1)];
	[groundGradient setContentSize:CGSizeMake(480,100)];
	[groundGradient setPosition:ccp(0,50)];
	[self addChild:groundGradient z:0 tag:TAG_GROUND_GRADIENT];
	
	//Add a sinister red glow gradient behind the evil samurai
	CCLayerGradient *redGradient = [CCLayerGradient layerWithColor:ccc4(0,0,0,0) fadingTo:ccc4(255,0,0,100) alongVector:ccp(1,0)];
	[redGradient setContentSize:CGSizeMake(200,200)];
	[redGradient setPosition:ccp(280,60)];
	[self addChild:redGradient z:2 tag:TAG_RED_GRADIENT];
	
	//Draw dramatic movie bars
	[self drawColoredSpriteAt:ccp(240,290) withRect:CGRectMake(0,0,480,60) withColor:ccc3(0,0,0) withZ:2];
	[self drawColoredSpriteAt:ccp(240,30) withRect:CGRectMake(0,0,480,60) withColor:ccc3(0,0,0) withZ:2];

	//Draw the good samurai
	CCSprite *goodSamurai = [CCSprite spriteWithFile:@"samurai_good.png"];
	goodSamurai.anchorPoint = ccp(0.5f,0);
	[goodSamurai setPosition:ccp(100,70)];
	[goodSamurai setScale:0.5f];
	[self addChild:goodSamurai z:1 tag:TAG_GOOD_SAMURAI];
	
	//Draw the evil samurai
	CCSprite *evilSamurai = [CCSprite spriteWithFile:@"samurai_evil.png"];
	evilSamurai.anchorPoint = ccp(0.5f,0);
	[evilSamurai setPosition:ccp(370,70)];
	[evilSamurai setFlipX:YES];
	[evilSamurai setScale:0.5f];
	[self addChild:evilSamurai z:1 tag:TAG_BAD_SAMURAI];
	
	// Make the swords glow
	[self glowAt:ccp(230,280) withScale:CGSizeMake(3.0f, 11.0f) withColor:ccc3(0,230,255) withRotation:45.0f withSprite:goodSamurai];
	[self glowAt:ccp(70,280) withScale:CGSizeMake(3.0f, 11.0f) withColor:ccc3(255,200,2) withRotation:-45.0f withSprite:evilSamurai];
	
	return self;	
}

-(void) initButtons {
	[CCMenuItemFont setFontSize:16];

	//'Fade to Black' button
	CCMenuItemFont* fadeToBlack = [CCMenuItemFont itemFromString:@"FADE TO BLACK" target:self selector:@selector(fadeToBlackCallback:)];
	CCMenu *fadeToBlackMenu = [CCMenu menuWithItems:fadeToBlack, nil];
    fadeToBlackMenu.position = ccp( 180 , 20 );
    [self addChild:fadeToBlackMenu z:4 tag:TAG_FADE_TO_BLACK];
	
	//'Fade to White' button
	CCMenuItemFont* fadeToWhite = [CCMenuItemFont itemFromString:@"FADE TO WHITE" target:self selector:@selector(fadeToWhiteCallback:)];
	CCMenu *fadeToWhiteMenu = [CCMenu menuWithItems:fadeToWhite, nil];
    fadeToWhiteMenu.position = ccp( 300 , 20 );
    [self addChild:fadeToWhiteMenu z:4 tag:TAG_FADE_TO_WHITE];	
}

/* Fade the scene to black */
-(void) fadeToBlackCallback:(id)sender {
	CCSprite *fadeSprite = [self getChildByTag:TAG_FADE_SPRITE];
	[fadeSprite stopAllActions];
	[fadeSprite setColor:ccc3(0,0,0)];
	[fadeSprite setOpacity:0.0f];
	[fadeSprite runAction: 
		[CCSequence actions:[CCFadeIn actionWithDuration:2.0f], [CCFadeOut actionWithDuration:2.0f], nil] ];	
}

/* Fade the scene to white */
-(void) fadeToWhiteCallback:(id)sender {
	CCSprite *fadeSprite = [self getChildByTag:TAG_FADE_SPRITE];
	[fadeSprite stopAllActions];
	[fadeSprite setColor:ccc3(255,255,255)];
	[fadeSprite setOpacity:0.0f];
	[fadeSprite runAction: 
		[CCSequence actions:[CCFadeIn actionWithDuration:2.0f], [CCFadeOut actionWithDuration:2.0f], nil] ];	
}

/* Draw a colored sprite */
-(void) drawColoredSpriteAt:(CGPoint)position withRect:(CGRect)rect withColor:(ccColor3B)color withZ:(float)z {
	CCSprite *sprite = [CCSprite spriteWithFile:@"blank.png"];
	[sprite setPosition:position];
	[sprite setTextureRect:rect];
	[sprite setColor:color];
	[self addChild:sprite];
	
	//Set Z Order
	[self reorderChild:sprite z:z];
}

/* Create a glow effect */
-(void) glowAt:(CGPoint)position withScale:(CGSize)size withColor:(ccColor3B)color withRotation:(float)rotation withSprite:(CCSprite*)sprite {
	CCSprite *glowSprite = [CCSprite spriteWithFile:@"fire.png"];
	[glowSprite setColor:color];
	[glowSprite setPosition:position];
	[glowSprite setRotation:rotation];
	[glowSprite setBlendFunc: (ccBlendFunc) { GL_ONE, GL_ONE }];
	[glowSprite runAction: [CCRepeatForever actionWithAction:
		[CCSequence actions:[CCScaleTo actionWithDuration:0.9f scaleX:size.width scaleY:size.height], [CCScaleTo actionWithDuration:0.9f scaleX:size.width*0.75f scaleY:size.height*0.75f], nil] ] ];	
	[glowSprite runAction: [CCRepeatForever actionWithAction:
		[CCSequence actions:[CCFadeTo actionWithDuration:0.9f opacity:150], [CCFadeTo actionWithDuration:0.9f opacity:255], nil] ] ];	
		
	[sprite addChild:glowSprite];
}

@end
分享到:
评论

相关推荐

    Cocos2d-x实战:JS卷——Cocos2d-JS开发

    资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...

    cocos2d-android jar包全套.zip

    Cocos2d是一款开源的游戏开发框架,被广泛用于创建2D游戏、演示程序和其他互动内容。在Android平台上,Cocos2d-x是一个基于C++的版本,提供了原生的编程接口,同时也支持Java API,方便Android开发者使用。"cocos2d-...

    Cocos2d-x实战 JS卷 Cocos2d-JS开发

    《Cocos2d-x实战 JS卷 Cocos2d-JS开发》是一本深入探讨Cocos2d-x游戏引擎JavaScript版本使用的专业书籍。Cocos2d-x是全球范围内广泛采用的游戏开发框架,尤其适用于2D游戏的制作,而Cocos2d-JS则是其JavaScript接口...

    cocos2d-x windows vs2010配置

    "cocos2d-x windows vs2010 配置详解" 本文将详细介绍如何在 Windows 环境下使用 Visual Studio 2010 配置 Cocos2d-x 游戏引擎。Cocos2d-x 是一个跨平台的游戏引擎,可以在多种平台上运行,包括 Windows、Mac OS X...

    cocos2d-x json字符串与cocos2d::Value转换工具

    该资源主要用于cocos2d-x中Value与json字符串的相互转换,提供从json文件读取为cocos2d::Value,cocos2d::Value写入到文件,cocos2d::Value转换为json字符串,json字符串转换为cocos2d::Value。json字符串转换成cocos...

    Cocos2d-x实战C++卷关东升著完整版pdf

    《Cocos2d-x实战C++卷》是关东升所著的一本深入探讨Cocos2d-x游戏引擎开发的专业书籍。Cocos2d-x是一个开源的、跨平台的2D游戏开发框架,广泛应用于iOS、Android、Windows等多个操作系统。本书以C++语言为主要编程...

    cocos2d-x 3.0

    《cocos2d-x 3.0:游戏开发中的角色移动技术详解》 在游戏开发领域,cocos2d-x是一款广泛使用的开源2D游戏引擎,尤其在移动平台上的应用非常广泛。cocos2d-x 3.0版本带来了许多性能优化和新特性,使得开发者能够更...

    Cocos2d-x 3.x游戏开发实战pdf含目录

    《Cocos2d-x 3.x游戏开发实战》是一本深度探讨Cocos2d-x 3.x框架的游戏开发书籍,适合对游戏编程有兴趣的开发者学习。Cocos2d-x 是一个开源的、跨平台的2D游戏开发框架,广泛应用于iOS、Android、Windows等多平台的...

    cocos2d入门cocos2d入门

    cocos2d入门 cocos2d入门 cocos2d入门 cocos2d入门 cocos2d入门 cocos2d入门

    Cocos2d-x实战:C++卷(2版)源代码

    《Cocos2d-x实战:C++卷(2版)源代码》这本书是关于使用Cocos2d-x游戏引擎进行游戏开发的专业指南。Cocos2d-x是一个开源的、跨平台的游戏开发框架,广泛应用于iOS、Android、Windows等多个操作系统。本书以C++语言...

    Cocos2d-x实战 JS卷

    《Cocos2d-x实战 JS卷》是一本深入探讨Cocos2d-x游戏开发的专著,主要聚焦于使用JavaScript语言进行游戏编程。Cocos2d-x是一个开源的游戏开发框架,广泛应用于移动设备和桌面平台,支持iOS、Android、Windows等多...

    cocos2d-x 动画工具 Flash2Cocos2d-x 1.3

    《cocos2d-x 动画工具 Flash2Cocos2d-x 1.3:将Flash创意带入移动游戏开发》 在移动游戏开发领域,cocos2d-x是一款广泛使用的开源游戏引擎,以其高效、跨平台的特性深受开发者喜爱。而Flash2Cocos2d-x则是一个专为...

    Cocos2d-JS游戏开发

    Cocos2d-JS是一款强大的2D游戏开发框架,它结合了JavaScript的灵活性与Cocos2d-x的高效性能,让开发者能够轻松地创建跨平台的游戏。本篇将深入探讨Cocos2d-JS的游戏开发知识,从基础到进阶,帮助你掌握这一利器。 ...

    cocos2d-iphone-2.0.tar.gz

    Cocos2d-iPhone是一个广泛使用的2D游戏开发框架,专为iOS设备(如iPhone和iPad)设计。这个开源项目让开发者能够轻松地创建高质量的游戏、应用和交互式内容,而无需深入理解底层图形和物理编程。"cocos2d-iphone-2.0...

    Cocos2d-html5

    Cocos2d-html5是一个基于Web的开源游戏开发框架,专为创建2D游戏、交互式应用程序和动画而设计。这个框架充分利用了HTML5、CSS3和JavaScript等现代Web技术,使得开发者能够在浏览器环境中构建高性能的游戏应用。...

    cocos2d的学习资料

    Cocos2d是一款广泛应用于游戏开发、图形界面和2D应用程序的开源框架,它支持多种编程语言,包括Python(cocos2d),Objective-C(cocos2d-objc)以及C++(cocos2d-x)。这篇学习资料是针对cocos2d/x,特别是cocos2d-...

    cocos2d学习资源汇总

    cocos2d-x学习资源汇总 cocos2d-x是一款功能强大且广泛应用于游戏开发的游戏引擎,由于其跨平台、开源、自由的特性,吸引了许多开发者的关注。以下是关于cocos2d-x的学习资源汇总,旨在帮助初学者快速入门和提高...

    cocos2d-x 跑酷源码

    《cocos2d-x 跑酷源码详解:打造属于你的移动跑酷游戏》 在移动游戏开发领域,cocos2d-x是一款广受欢迎的开源2D游戏引擎,它基于C++,支持iOS、Android以及其他多种平台。本文将深入探讨如何利用cocos2d-x开发一款...

    Cocos2d-x 闪电特效

    Cocos2d-x是一款流行的开源游戏开发框架,它基于C++,并利用OpenGL进行图形渲染。在游戏开发中,特效的实现是至关重要的,能够极大地提升游戏的视觉体验和玩家的沉浸感。"Cocos2d-x 闪电特效"正是这样一个专题,它...

    别踩白块游戏cocos2d-x3.x实现

    在这个项目中,我们将会使用Cocos2d-x 3.x版本来实现这款游戏。Cocos2d-x是一个广泛使用的开源游戏引擎,尤其适合2D游戏开发,它支持多种编程语言,包括C++、Lua和JavaScript。 首先,我们需要了解Cocos2d-x的基本...

Global site tag (gtag.js) - Google Analytics