【Cocos2d入门教程五】Cocos2d-x动作篇

动作类(Action)是所有动作的基类,它创建的一个对象代表一个动作。动作作用于Node,包括继承于之下的Layer、Sprite。因此每个动作都需要由Node对象或者其继承者执行。动作类(Action)作为基类,实际上是一个接口,动作类的大多数实现类都派生于有限时间动作类(FiniteTimeAction)。其关系图如下:



在实际开发中我们通常用到两类动作-即时动作和持续动作,它们均继承于有限时间动作类。

1. 即时动作

  放置Place

  隐藏 Hide

  显示 Show

  可见切换ToggleVisibility

 

2.延时动作

  移动到MoveTo

  移动 MoveBy

  跳跃到JumpTo 

  跳跃JumpBy   

  贝塞尔BezierBy  

  放大到ScaleTo   设置放大倍数,是浮点型。

  放大ScaleBy

  旋转到RotateTo

  旋转RotateBy

  闪烁Blink   设定闪烁次数

  色调变化到TintTo

  色调变换TintBy

  变暗到FadeTo

  由无变亮FadeIn

  由亮变无FadeOut

 

3.组合动作

  序列 Sequence

  同步Spawn

  重复有线次数Repeate

  动作反向Reverse

  动画Animation

  无限重复RepeatForever

 

4.速度变化

  EaseIn 由慢至快。

  EaseOut 由快至慢

  EaseInOut 由慢至快再由快至慢。

  EaseSineIn 由慢至快。

  EaseSineOut 由快至慢

  EaseSineInOut 由慢至快再由快至慢。

  EaseExponentialIn 由慢至极快。

  EaseExponentialOut 由极快至慢。

  EaseExponentialInOut由慢至极快再由极快至慢。

  Speed 人工设定速度,还可通过SetSpeed不断调整

下面以几个常用函数作为案例:

    Menu * menu =Menu::create();
    
    menu ->setPosition(Vec2::ZERO);
    
    addChild(menu);
    
    //-----------------------------------------------------------------------
    //Flip
    MenuItemFont * FlipItem =MenuItemFont::create("Filp",CC_CALLBACK_1(NewScene::bgFlip, this));
    
    FlipItem ->setPosition(60,350);
    
    menu->addChild(FlipItem);
    
    
    void NewScene::bgFlip(Ref * ref)
    {
        if (testSp ->isFlippedX())
        {
            
            FlipX * fx = FlipX ::create(false);
            
            testSp ->runAction(fx);
            
        }
        else
        {
            
            FlipX * fx = FlipX ::create(true);
            
            testSp ->runAction(fx);
        }
    }
    
    
    //-----------------------------------------------------------------------
    //MoveTo
    MenuItemFont * MoveItem =MenuItemFont::create("MoveTo",CC_CALLBACK_1(NewScene::bgMove, this));
    
    MoveItem ->setPosition(60,300);
    
    menu->addChild(MoveItem);
    
    
    void NewScene::bgMove(Ref* psend)
    {
        MoveTo * moveAct = MoveTo::create(0.5,Vec2(400, 400));
        
        testSp ->runAction(moveAct);
    }
    
    
    
    //-----------------------------------------------------------------------
    //RatateTo
    MenuItemFont * RotateItem =MenuItemFont::create("RotateTo",CC_CALLBACK_1(NewScene::bgRotate, this));
    
    RotateItem ->setPosition(60,250);
    
    menu->addChild(RotateItem);
    
    
    
    void NewScene::bgRotate(Ref * ref)
    {
        RotateTo * rotate =RotateTo::create(0.5, 100, 100);
        
        testSp ->runAction(rotate);
    }
    
    
    
    
    //-----------------------------------------------------------------------
    //ScaleTo
    MenuItemFont * ScaleItem =MenuItemFont::create("ScaleTo",CC_CALLBACK_1(NewScene::bgScale, this));
    
    ScaleItem ->setPosition(60,200);
    
    menu->addChild(ScaleItem);
    
    
    void NewScene::bgScale(Ref* psend)
    {
        ScaleTo * scale =ScaleTo::create(0.5, 2);
        
        testSp ->runAction(scale);
    }
    
    
    
    //-----------------------------------------------------------------------
    //Hide Show
    MenuItemToggle * toggleMenu =MenuItemToggle::createWithCallback(
                                                                    CC_CALLBACK_1(NewScene::bgToggle,this),
                                                                    MenuItemFont::create("Show"),
                                                                    MenuItemFont::create("Hide"),
                                                                    NULL);
    
    toggleMenu ->setPosition(60,150);
    
    menu ->addChild(toggleMenu);
    
    
    void NewScene::bgToggle(Ref * ref)
    {
        if(testSp->isVisible())
        {
            Hide * hide =Hide::create();
            testSp ->runAction(hide);
            ShowTag =0;
        }
        else
        {
            Show * show =Show ::create();
            testSp ->runAction(show);
            ShowTag =1;
        }
        
    }
    
    
    
    //-----------------------------------------------------------------------
    //FadeIn FadeOut
    MenuItemToggle * FadeToggle =MenuItemToggle::createWithCallback(
                                                                    CC_CALLBACK_1(NewScene::FadeToggle,this),
                                                                    MenuItemFont::create("FadeIN"),
                                                                    MenuItemFont::create("FadeOut"),
                                                                    NULL);
    
    FadeToggle ->setPosition(60,100);
    
    menu ->addChild(FadeToggle);
    
    
    void NewScene::FadeToggle(Ref * ref)
    {
        if(FadeTag == 1)
        {
            FadeOut *  FadeOut = FadeOut ::create(1);
            
            testSp ->runAction(FadeOut);
            
            FadeTag = 0;
        }
        else if (FadeTag == 0)
        {
            FadeIn * FadeIn = FadeIn ::create(1);
            
            testSp ->runAction(FadeIn);
            
            FadeTag = 1 ;
        }
        
    }
    
    
    //-----------------------------------------------------------------------
    //曲线运动
    MenuItemFont * Cardin =MenuItemFont::create("Cardin",CC_CALLBACK_1(NewScene::CardIn, this));
    
    Cardin ->setPosition(60,50);
    
    menu->addChild(Cardin);
    
    
    void NewScene::CardIn(Ref * ref)
    {
        PointArray  * array = PointArray ::create(20);
        
        array ->addControlPoint(Point(100,100));
        
        array ->addControlPoint(Point(200,400));
        
        array ->addControlPoint(Point(300,500));
        
        CardinalSplineTo * CardIn = CardinalSplineTo::create(1, array, 5);
        
        testSp ->runAction(CardIn);
    }
注意:这里需要注意To跟By的不同,To的话在坐标系中是以绝对位置,By的话在坐标系中是以node对象的相对位置进行执行动作。

如果你想搭配reverse()一起用的话用To是无效的,必须用By.


Ok.关于Cocos2d-x的动作就分享至此。不对的地方还望指出互相探讨学习

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值