使用CCAnimate、CCAnimation、CCTextureCache、CCTexture2D来实现动画效果
2014-08-22 15:35
459 查看
使用CCTexture2D来创建动画效果,前提资源是有一张合成的大图
下面看具体的做法:
CCSprite* heroSprite = CCSprite::create();
heroSprite -> setAnchorPoint(ccp(0.35,0.3));
heroSprite -> setPosition(ccp(heroSprite -> getContentSize().width/2, m_winSize.height/2));
this -> addCHild(heroSprite,1,0);
CCAnimation* animation = CCAnimation::create();
animation -> setDelayPerUnit(0.3f);//设定时间间隔
animation -> setLoops(-1);//(-1)表示一直执行
CCTextureCache* cache = CCTextrueCache::sharedTextureCache();
CCTexture2D* texture = cache -> addImage("background.png");//这张图片上有要实现运动的各个图片
for(int i = 0; i < 5; i++)
{
CCRect rect = CCRectMake(85*i,0,85,121);
animation -> addSpriteFrameWithTexture(texture,rect);
}
CCAnimate* animate = CCAnmiate::create(animation);
heroSprite -> runAction(animate);
当然,如果你的图片是自己合成的,就应该有plist文件,这时候,就不用使用CCTexture2D来实现动画效果了,还有一个更简单的方法
例如:
CCSpriteFrameCache* cache = CCSpriteFrameCache::sharedSpriteFrameCache();
cache -> addSpriteFrameWithFile("background.plist");
char temp[20];
CCArray* plistArray = CCArray::createWithCapacity(10);
for(int i = 0; i < 10; i++)
{
sprintf(temp,"pook%d",i);
CCSpriteFrame* frame = cache -> spriteFrameByName(temp);
plistArray -> addObject(frame);
}
CCAnimation* animation = CCAnimation::createWithSpriteFrames(plistArray,0.1);
CCAnimate* animate = CCAnimate::create(animation);
//然后让执行此动画的精灵开始执行animate即可
//heroSprite -> runAction(animte);
下面看具体的做法:
CCSprite* heroSprite = CCSprite::create();
heroSprite -> setAnchorPoint(ccp(0.35,0.3));
heroSprite -> setPosition(ccp(heroSprite -> getContentSize().width/2, m_winSize.height/2));
this -> addCHild(heroSprite,1,0);
CCAnimation* animation = CCAnimation::create();
animation -> setDelayPerUnit(0.3f);//设定时间间隔
animation -> setLoops(-1);//(-1)表示一直执行
CCTextureCache* cache = CCTextrueCache::sharedTextureCache();
CCTexture2D* texture = cache -> addImage("background.png");//这张图片上有要实现运动的各个图片
for(int i = 0; i < 5; i++)
{
CCRect rect = CCRectMake(85*i,0,85,121);
animation -> addSpriteFrameWithTexture(texture,rect);
}
CCAnimate* animate = CCAnmiate::create(animation);
heroSprite -> runAction(animate);
当然,如果你的图片是自己合成的,就应该有plist文件,这时候,就不用使用CCTexture2D来实现动画效果了,还有一个更简单的方法
例如:
CCSpriteFrameCache* cache = CCSpriteFrameCache::sharedSpriteFrameCache();
cache -> addSpriteFrameWithFile("background.plist");
char temp[20];
CCArray* plistArray = CCArray::createWithCapacity(10);
for(int i = 0; i < 10; i++)
{
sprintf(temp,"pook%d",i);
CCSpriteFrame* frame = cache -> spriteFrameByName(temp);
plistArray -> addObject(frame);
}
CCAnimation* animation = CCAnimation::createWithSpriteFrames(plistArray,0.1);
CCAnimate* animate = CCAnimate::create(animation);
//然后让执行此动画的精灵开始执行animate即可
//heroSprite -> runAction(animte);
相关文章推荐
- cocos2d-x 动画详解之零 基础CCTexture2D,CCTextureAtlas,CCTextureCache
- 缓存与预加载技术(图片缓存CCSpriteFrameCache、动画缓存 CCAnimationCache、纹理缓存CCTextureCache、音乐音效SimpleAudioEngine)
- 使用silverlight中的Storyboard实现动画效果
- 使用C#实现WinForm窗体的动画效果
- Flex4之自定义动画效果,使用自定义Parallel类来实现
- Android中使用Animation实现控件的动画效果以及Interpolator和AnimationListener的使用
- 使用Silverlight实现 FLASH的动画效果
- cocos2d-x 使用action实现各种动画效果
- Android中使用Animation实现控件的动画效果以及Interpolator和AnimationListener的使用
- 使用NSTimer与iphone的简单动画,实现飘雪效果
- Android中使用Animation实现控件的动画效果以及Interpolator和AnimationListener的使用
- 使用Layer类和Sprite类实现手机游戏的动画效果
- 使用NSTimer与UIView的动画,实现飘雪效果
- Android中使用Animation实现控件的动画效果以及Interpolator和AnimationListener的使用
- 使用silverlight中的Storyboard实现动画效果
- 使用C#实现WinForm窗体的动画效果
- 使用C#实现WINFORM窗体的动画效果
- 使用jQuery来实现菜单文字和图标动画效果
- cocos2d-x CCTextureCache使用
- iphone--使用NSTimer与iphone的简单动画,实现飘雪效果