cocos2d 动作概念的整理

原本计划是把动作的概念理清,并分类介绍如何使用,但是网上看到几篇写得比较详细,而且都有实例,在此就转载一下,并表示一下感谢。

//////////////////这一段转自Cocos2d-x官方中文文档 v3.x////////////////////////////

动作类(Action)是所有动作的基类,它创建的一个对象代表一个动作。动作作用于Node,因此每个动作都需要由Node对象执行。动作类(Action)作为基类,实际上是一个接口,动作类的大多数实现类都派生于有限时间动作类(FiniteTimeAction)。

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

即时动作

即时动作只能够立刻完成的动作,这类动作是在下一帧立刻完成的动作,如设定位置、设定缩放等。把它们包装成动作后,可以与其他动作类组合为复杂动作。

下面介绍一些常用即时动作

Place

该动作用于将节点放置到某个指定位置,其作用与修改节点的position属性相同。例如,将节点放到屏幕坐标(10,10)处的代码如下:

<span class="pln" style="color: rgb(255,255,255);">    </span><span class="kwd" style="color: rgb(226,137,100);">auto</span><span class="pln" style="color: rgb(255,255);"> placeAction </span><span class="pun" style="color: rgb(255,255);">=</span><span class="pln" style="color: rgb(255,255);"> </span><span class="typ" style="color: rgb(137,189,255);">Place</span><span class="pun" style="color: rgb(255,255);">::</span><span class="pln" style="color: rgb(255,255);">create</span><span class="pun" style="color: rgb(255,255);">(</span><span class="typ" style="color: rgb(137,255);">Point</span><span class="pun" style="color: rgb(255,255);">(</span><span class="lit" style="color: rgb(51,135,204);">10</span><span class="pun" style="color: rgb(255,255);">,</span><span class="pln" style="color: rgb(255,255);"> </span><span class="lit" style="color: rgb(51,255);">));</span>

FlipX和FlipY

这两个动作分别用于将精力沿X轴和Y轴反向显示,其作用与设置精灵的FlipX和FlipY属性相同,将其包装成动作是为了便于与其他动作进行组合。

下面代码将一个精灵移动到一端后反向显示再进行移回原点的动作:

 

其中Sequence是动作序列,后面将详细介绍,reverse的作用是获得原动作的逆动作。

Show和Hide

这两个动作分别用于显示和隐藏节点,其作用与设置节点的visible属性作用一样。例如,为了使精灵完成移动后隐藏起来,可以用如下代码:

 

CallFunc

CallFunc系列动作包括CallFunc、CallFuncN两个动作,用来在动作中进行方法调用。在游戏中为了节约内存资源,我们可以在动作完成后调用相应函数清理内存,如下代码:

 

持续动作

属性变化动作

属性变化动作通过属性值的逐渐变化来实现动画效果。需要注意的是XXTo和XXBy的区别在于XXTo是表示最终值,而XXBy则表示向量-改变值。

MoveTo和MoveBy

用于使节点做直线运动,设置了动作时间和终点位置,在规定时间内会移动到终点,它们的初始化方法如下:

 MoveTo的position值表示最后位置,而MoveBy的position则表示移动的位置。

JumpTo和JumpBy

使节点以一定的轨迹跳跃到指定位置,它们的初始化方法如下:

 BezierTo和BezierBy

使节点进行曲线运动,运动的轨迹由贝塞尔曲线描述。

每条贝塞尔曲线都包含一个起点和一个终点。在一条曲线中,起点和终点各自包含一个控制点,而控制点到端点的连线称作控制线。控制点决定了曲线的形状,包含角度和长度两个参数。如下图:

使用时,我们要先创建ccBezierConfig结构体,设置好终点endPosition以及两个两个控制点controlPoint_1和controlPoint_2后,再把结构体传入BezierTo或BezierBy的初始化方法中:

 ScaleTo和ScaleBy

产生缩放效果,使节点的缩放系数随时间线性变化,对应初始化方法为:

 RotateTo和RotateBy

产生旋转效果,对应初始化方法为:

 视觉特效动作 

该类用来实现特殊视觉效果

FadeIn,FadeOut和FateTo

产生淡入淡出效果,和透明变化效果,对应的初始化方法为:

 

TintTo和TintBy

设置色调变化,这个动作较少使用,初始化方法为:

 red,green,blue的取值范围为0~255

Blink

使节点闪烁,其初始化方法为:

 其中blinks为闪烁次数

Animation

以帧动画形式实现动画效果,以下代码用两种方法实现精灵帧动画效果:

 

动画创建后需要一个动画播放器来播放这些动画,这个播放器就是Animate。

复合动作

通常在开发中我们需要将各种动作组合起来再让节点执行,复合动作的作用就是将各种动作组合在一起。而且,复合动作本身也是动作。因此可以作为一个普通动作嵌入到其他动作中。

注意:Sequence动作不能嵌入其他复合动作内使用,DelayTime不属于复合动作,但是只能在复合动作内使用。

DelayTime

延时动作其实什么都不做,提供一段空白期,它只有一个初始化方法:

 d表示需要延时的时间。

Repeat/RepeatForever

反复执行某个动作,通常我们用Repeat和RepeatForever这两个方法执行:

 Spawn

使一批动作同时执行,他的两个初始化方法:

 Sequence

让各种动作有序执行,以下为它的两个初始化方法:

 变速动作 

变速动作和符合动作类似,也是一种特殊的动作,它可以把任何动作按照改变后的速度执行。

Speed

用于线性的改变某个动作的速度,为了改变一个动作的速度,首先需要将目标动作包装到Speed动作中:

 第二个参数为变速比例,设置为0.5f则速度为原来一半。

ActionEase

Speed虽然能改变动作的速度,但是只能按比例改变速度,ActionEase可以实现动作的速度由快到慢、速度随时间改变的匀速运动。该类包含5类运动,指数缓冲、Sine缓冲、弹性缓冲、跳跃缓冲和回震缓冲。每类运动都包含3个不同时期的变换:In、Out和InOut。

以下以InSine为例:

 

*****************这一段转自ArmyShen的http://www.cnblogs.com/ArmyShen/p/3239677.html**************

1、动作基本概念

CCAction是动作的基类,所有的动作都派生自此类。CCAction的一个对象就是一个动作,动作或动画只能由CCNode来执行

CCSprite* sp = CCSprite::create("Icon.png");//创建一个精灵
sp->setPosition( ccp(20,20) );设置精灵初始位置
this->addChild(sp,128); line-height:1.5!important">0);添加精灵到场景中
CCAction *action = CCMoveTo::create(1.0f,ccp(0,128); line-height:1.5!important">0));创建一个CCMoveTo动作,1s之内移动到ccp(0,0)位置
sp->runAction(action);执行动作

同一时间段内,一个动作只能由一个CCNode来执行,如果想N个CCNode同时执行一个动作,要使用copy复制动作:

CCAction *action = CCMoveTo::create(4.0f,128); line-height:1.5!important">0));
sp1->runAction((CCAction *)action->copy());

CCAction有一个派生类CCFiniteTimeAction,这个类中定义了一个reverse方法,此方法的作用是逆置动作,就是原动作的相反动作。绝大数我们使用的动作类都派生自CCFiniteTimeAction,如最常用的CCActionInterval(持续性动作)、CCActionInstant(瞬时动作),这两个类又分别派生出许多我们实际用到的动作类。

2、瞬时动作

瞬时动作就是立刻完成的动作,其持续的动作时间为0,这些动作的实现可以通过设置CCNode的属性来完成,通过动作的封装,使其可以和其他动作组合成复杂的动作。

常用的瞬时动作:

1)CCPlace -- 将该节点放置到某个位置,和设置CCNode中的Position属性效果相同

CCFiniteTimeAction *action = CCPlace::create(ccp(0));
sp->runAction(action);

2)CCFlipX和CCFlipY -- 将节点沿X和Y反向显示,与CCNode中的FlipX和FlipY效果相同

CCFiniteTimeAction *action = CCFlipX::create(true);
CCFiniteTimeAction *action = CCFlipY::create(true);
sp->runAction(action);

3)CCShow和CCHide -- 分别用于显示和隐藏节点,和Visible效果相同

CCFiniteTimeAction *action1 = CCHide::create(); CCFiniteTimeAction *action2 = CCShow::create(); sp->runAction(action2);

3、动作回调函数

当一个CCNode执行完某个Action后,我们可能需要做一些其他的工作,这时,可以使用动作回调函数来完成这项功能。在一个动作完成之后随即调用动作回调函数,这种类型的函数有4种形式可供我们选择使用:

1)CCCallFunc:无参回调函数

创建一个在1s内移动到ccp(0,0)位置的动作
CCFiniteTimeAction *action = CCMoveTo::create(1,128); line-height:1.5!important">0));
创建一个在1s内移动到ccp(size.width/2,size.height/2)位置的动作
CCFiniteTimeAction *action1 = CCMoveTo::create(2,size.height/2));
创建不带参数的动作回调,当动作执行完成后,调用该函数
CCFiniteTimeAction *action2 = CCCallFunc::create(this,callfunc_selector(HelloWorld::actionCallBack));
循环执行动作
sp->runAction(CCRepeatForever::create(CCSequence::create(action,action1,action2,NULL)));

void HelloWorld::actionCallBack()
{
    设置背景显示/隐藏
    if(m_SpBackground->isVisible())
    {
        m_SpBackground->setVisible(false);
    }
    else
    {
        m_SpBackground->setVisible(true);
    }
}

2)CCCallFuncN:带一个CCNode*参数回调函数,“N”表示CCNode

创建带一个CCNode*参数的动作回调,当动作执行完成后,调用并向该函数传递执行动作的那个CCNode对象 CCFiniteTimeAction *action2 = CCCallFuncN::create(void HelloWorld::actionCallBack(cocos2d::CCNode *node) { 参数node就是执行动作的那个对象,这里测试每次动作执行完成后,设置这个对象的缩放值 CCAssert(node,0); line-height:1.5!important">node is null"); if (node->getScaleX() > 1.0f || node->getScaleY() > 1.0f) { node->setScale(1.0f); } else { node->setScale(2.0f); } }
3)CCCallFuncND:带一个CCNode*和一个void*参数的回调函数,“N”表示CCNode,"D"表示Data

创建带一个CCNode*和一个Void*参数的动作回调,当动作执行完成后,调用并向该函数传递执行动作的那个CCNode对象和用户自定义的数据对象m_nCount CCFiniteTimeAction *action2 = CCCallFuncND::create(this,callfuncND_selector(HelloWorld::actionCallBack),(void*)&m_nCount); void HelloWorld::actionCallBack(cocos2d::CCNode *node,int *i) { CCAssert(node,i是我们自己传递进来的m_nCount printf(%d\n",*i); 每执行一次动作,让计数器加1 m_nCount++; 这个node就是执行动作的那个对象,每次动作执行完成后,设置这个对象的缩放值 4)CCCallFunO:带一个CCObject*参数的回调函数,"O"表示CCObject

创建带一个CCObject*参数的动作回调,当动作执行完成后,调用并向该函数传递CCObject对象m_SpBackground CCFiniteTimeAction *action2 = CCCallFuncO::create(void HelloWorld::actionCallBack(cocos2d::CCObject *obj) { CCAssert(obj,0); line-height:1.5!important">obj is nullobj是我们传递进来的m_SpBackground,是一个CCSprite类型 CCNode *node = (CCNode*)obj; 测试设置背景的显示/隐藏 if (node->isVisible()) { node->setVisible(else { node->setVisible(4、持续性动作

持续性动作:指持续一段时间逐渐完成的动作。

1)位置变化动作

常用的位置变化动作有:CCMoveTo / CCMoveBy(节点直线运动)、CCJumpTo / CCJumpBy(节点跳跃运动)、CCBezierTo /CCBezierBy(节点曲线运动)

以To结尾的持续性动作,设置节点坐标位置的绝对变化。简单的讲就是将节点从位置A直接移动到位置B,移动参照位置应该是当前场景,比如说节点现在在场景A(100,100)的位置,使用To结尾的动作,可以将节点直接移动到场景的B(0,0)位置。

以By结尾的持续性动作和To最大的不同就是移动参照位置的不同。以By结尾的动作,是设置节点位置的相对变化。比方说节点现在在场景中的位置是A(100,100),使用By结尾的动作移动到B(200,200),此时并不是把节点从位置A移动到位置B,而是以这个节点的自身为参照,移动B这么多的像素,再简单点讲就是使用By结尾的动作时,节点始终把自己的移动初始位置看做(0,0),与它的实际场景位置无关,x轴、y轴分别移动N个像素距离。

CCMoveTo / CCMoveBy(节点直线运动)

duration -- 动作持续时长 deltaPosition -- 移动位置(To)、移动距离(By) CCMoveTo::create(float duration,255); line-height:1.5!important">const CCPoint& deltaPosition); CCMoveBy::create(const CCPoint& deltaPosition);

CCJumpTo / CCJumpBy(节点跳跃运动)

deltaPosition -- 移动位置(To)、移动距离(By) height -- 跳跃高度 jumps -- 跳跃次数 CCJumpTo::create(const CCPoint& position,255); line-height:1.5!important">float height,unsigned int jumps); CCJumpBy::create(int jumps);

CCBezierTo /CCBezierBy(节点曲线运动)

使用贝塞尔曲线让节点做曲线运动,需先创建ccBezierConfig结构体,设置曲线的第一第二控制点和结束位置

ccBezierConfig con;
con.controlPoint_1 = ccp(100,128); line-height:1.5!important">100);
con.controlPoint_2 = ccp(200,128); line-height:1.5!important">200);
con.endPosition = ccp(0);
CCActionInterval *action1 = CCBezierTo::create(3,con);
CCActionInterval *action1 = CCBezierBy::create(3,con);
sp->runAction(CCSequence::create(action1,NULL));
2)属性变化动作

CCScalsTo / CCScaleBy(节点缩放)

设置CCSprite类型节点sp的缩放值 sp->setScale(0.25); 在规定时间内将节点sp以原始比例缩放2倍大小,也就是说按照setScale(1)的比例缩放2倍,忽略节点之前的缩放 CCFiniteTimeAction *action = CCScaleTo::create(0.5,128); line-height:1.5!important">2); 在规定时间内将节点sp按照当前比例缩放2倍大小,也就是按照setScale(0.25)的比例缩放2倍 CCFiniteTimeAction *action = CCScaleBy::create(2); sp->runAction(CCSequence::create(action,245)"> CCRotateTo / CCRotateBy(节点旋转)

sp->setRotation(45);
在规定时间内将节点sp以原始角度进行旋转,也就是按照setRotation(0)的角度进行旋转,忽略之前的旋转角度
CCFiniteTimeAction *action = CCRotateTo::create(0);
在规定时间内将节点sp以现有角度进行旋转,也就是在setRotation(45)的角度基础上进行叠加旋转
CCFiniteTimeAction *action = CCRotateBy::create(1,10);

CCFadeIn /CCFadeOut(淡入淡出)

这两种效果都实现了reverse方法 淡入 CCFadeIn::create(float d) 淡出 CCFadeOut::create(float d)

CCFadeTo(一段时间内的透明度变化,只能用于CCSprite)

duration -- 动作执行时长 opacity --透明度(0~255) CCFadeTo::create( CCTintBy / CCTintTo(色调变化,与CCFadeTo类似)

duration -- 执行时长 r、g、b颜色值,取值范围0~255 CCTintTo::create(float duration,GLubyte red,GLubyte green,GLubyte blue) CCTintBy::create( CCBlink(节点闪烁)

时间长度 uBlinks -- 闪烁次数 CCBlink::create(int uBlinks)

5、复合动作

1)重复动作 --CCRepeatForever / CCRepeat

使一个Action重复被执行

无限重复执行动作 CCRepeatForever* create(CCActionInterval *pAction); 重复执行times次 CCRepeat* create(CCFiniteTimeAction *pAction,255); line-height:1.5!important">int times); 例如 CCActionInterval *action = CCMoveBy::create(110,128); line-height:1.5!important">110)); CCActionInterval *action1 = action->reverse(); 无限重复执行动作 sp->runAction(CCRepeatForever::create(CCSequence::create(action,NULL)));
2)并列动作 -- CCSpawn

使一个CCNode同时执行一批动作,并列动作必须是能够同时执行并继承自CCFiniteTimeAction的动作,合并之后,动作执行完成时间按照最大的一个动作执行时间计算

CCScaleTo动作 CCActionInterval *action1 = CCScaleTo::create(0.5); CCRotateTo动作 CCActionInterval *action2 = CCRotateTo::create(180); 创建并列动作(使一个CCNode同时执行缩放和旋转动作),按照CCRotateTo(2秒)执行时间计算 CCActionInterval *act = CCSpawn::create(action1,NULL); 执行动作 sp->runAction(act);
3)序列动作 -- CCSequence

序列动作就是使一个CCNode顺序执行一批动作

CCMoveBy动作 CCActionInterval *action = CCMoveBy::create(110)); CCActionInterval *action_back = action->reverse(); 创建序列动作 CCActionInterval *act = CCSequence::create(action,action_back,255)">4)延时动作 -- CCDelayTime

110)); CCActionInterval *action_back = action->reverse(); 创建CCDelayTime CCDelayTime *delayTime = CCDelayTime::create(5); 创建序列动作,使action和action_back动作之间停顿5秒后再执行 CCActionInterval *act = CCSequence::create(action,delayTime,0)">6、变速动作

1)CCSpeed动作

线性改变某个动作的速度

100)); CCActionInterval *action_back = action->reverse(); 创建CCSpeed CCSpeed *speed = CCSpeed::create(CCSequence::create(action,NULL),128); line-height:1.5!important">1); 执行动作 sp->runAction(speed); 设置动作速度 speed->setSpeed(10);
2)CCActionEase系列动作

CCActionEase系列动作继承关系图

CCActionEase系列动作有相似的名字:CCEaseXxxxInCCEaseXxxxOutCCEaseXxxxInOut

In -- 表示动作执行先快后慢
Out -- 表示动作执行先慢后快
InOut -- 表示动作执行快-慢-快

使用CCActionEase系列创建动作,可以使动作的运动轨迹变得多样化,效果很不错


为了进一步了解一下CCCallFunc的的使用,下面引用多一篇好文章

-----------------------这一段引用自just_do_it2009的http://blog.csdn.net/just_do_it2009/article/details/8891651------------

CCCallFunc CCCallFuncN CCCallFuncND的区别和使用

CCCallFunc CCCallFuncN CCCallFuncND都用来创建带有回调函数的动作,区别主要在于回调函数是否带有参数

CCCallFunc

CCCallFunc是执行对应的回调函数,其中回调函数不可带参数。一般使用静态成员函数create创建实例,create声明如下:

<span class="kwd" style="color: rgb(0,136);">static</span><span class="pln" style="color: rgb(0,0);"> </span><span class="typ" style="color: rgb(102,102);">CCCallFunc</span><span class="pun" style="color: rgb(102,0);">*</span><span class="pln" style="color: rgb(0,0);"> create	</span><span class="pun" style="color: rgb(102,0);">(</span><span class="pln" style="color: rgb(0,0);">	</span><span class="typ" style="color: rgb(102,102);">CCObject</span><span class="pln" style="color: rgb(0,0);"> </span><span class="pun" style="color: rgb(102,0);"> 	pSelectorTarget</span><span class="pun" style="color: rgb(102,0);">,</span><span class="pln" style="color: rgb(0,0);">
SEL_CallFunc 	selector
</span><span class="pun" style="color: rgb(102,0);">)</span>

回调函数通过execute方法执行,CCCallFunc中的execute的实现如下:

 

通过(m_pSelectorTarget->*m_pCallFunc)();可以看到回调函数不包含参数

CCCallFuncN

CCCallFuncN也是执行对应的回调函数,其中回调函数带一个参数。一般使用静态成员函数create创建实例,create声明如下:

 回调函数通过execute方法执行,CCCallFuncN中的execute的实现如下:

 通过(m_pSelectorTarget->*m_pCallFuncN)(m_pTarget);可以看到回调函数包含一个参数。

CCCallFuncND

CCCallFuncND也是执行对应的回调函数,其中回调函数可带两个参数。一般使用静态成员函数create创建实例,create声明如下:

 回调函数通过execute方法执行,CCCallFuncND中的execute的实现如下:

 通过(m_pSelectorTarget->*m_pCallFuncND)(m_pTarget,m_pData);可以看到回调函数包含两个参数。

CCCallFunc CCCallFuncN CCCallFuncND实例对比

<span class="pln" style="color: rgb(0,0);">testCallFunc</span><span class="pun" style="color: rgb(102,0);">.</span><span class="pln" style="color: rgb(0,0);">h</span><span class="pun" style="color: rgb(102,0);">中代码</span><span class="pln" style="color: rgb(0,136);">class</span><span class="pln" style="color: rgb(0,0);"> testCallFunc </span><span class="pun" style="color: rgb(102,0);">:</span><span class="pln" style="color: rgb(0,0);"> </span><span class="kwd" style="color: rgb(0,136);">public</span><span class="pln" style="color: rgb(0,102);">CCLayer</span><span class="pln" style="color: rgb(0,136);">protected</span><span class="pun" style="color: rgb(102,0);">
    </span><span class="typ" style="color: rgb(102,102);">CCSprite</span><span class="pun" style="color: rgb(102,0);">    sprite1</span><span class="pun" style="color: rgb(102,0);">;</span><span class="pln" style="color: rgb(0,0);">    sprite2</span><span class="pun" style="color: rgb(102,0);">    sprite3</span><span class="pun" style="color: rgb(102,136);">public</span><span class="pun" style="color: rgb(102,136);">virtual</span><span class="pln" style="color: rgb(0,0);"> onEnter</span><span class="pun" style="color: rgb(102,0);">();</span><span class="pln" style="color: rgb(0,0);">

    </span><span class="kwd" style="color: rgb(0,0);"> callback1</span><span class="pun" style="color: rgb(102,0);"> callback2</span><span class="pun" style="color: rgb(102,0);">(</span><span class="typ" style="color: rgb(102,102);">CCNode</span><span class="pun" style="color: rgb(102,0);"> sender</span><span class="pun" style="color: rgb(102,0);"> callback3</span><span class="pun" style="color: rgb(102,136);">void</span><span class="pun" style="color: rgb(102,0);"> data</span><span class="pun" style="color: rgb(102,0);">};</span><span class="pln" style="color: rgb(0,0);">

testCallFunc</span><span class="pun" style="color: rgb(102,0);">cpp</span><span class="pun" style="color: rgb(102,0);">

</span><span class="kwd" style="color: rgb(0,0);"> testCallFunc</span><span class="pun" style="color: rgb(102,0);">onEnter</span><span class="pun" style="color: rgb(102,0);">
    </span><span class="com" style="color: rgb(136,0);">//CCCallFunc的使用</span><span class="pln" style="color: rgb(0,102);">CCFiniteTimeAction</span><span class="pun" style="color: rgb(102,0);">  action </span><span class="pun" style="color: rgb(102,0);">=</span><span class="pln" style="color: rgb(0,102);">CCSequence</span><span class="pun" style="color: rgb(102,0);">create</span><span class="pun" style="color: rgb(102,0);">
        </span><span class="typ" style="color: rgb(102,102);">CCMoveBy</span><span class="pun" style="color: rgb(102,0);">(</span><span class="lit" style="color: rgb(0,102);">2</span><span class="pun" style="color: rgb(102,0);"> ccp</span><span class="pun" style="color: rgb(102,102);">200</span><span class="pun" style="color: rgb(102,</span><span class="lit" style="color: rgb(0,102);">0</span><span class="pun" style="color: rgb(102,0);">)),0);"> callfunc_selector</span><span class="pun" style="color: rgb(102,0);">callback1</span><span class="pun" style="color: rgb(102,0);">
        NULL</span><span class="pun" style="color: rgb(102,0);">

    </span><span class="com" style="color: rgb(136,0);">//CCCallFuncN的使用</span><span class="pln" style="color: rgb(0,0);">  action2 </span><span class="pun" style="color: rgb(102,102);">CCScaleBy</span><span class="pun" style="color: rgb(102,102);">2</span><span class="pln" style="color: rgb(0,0);">  </span><span class="lit" style="color: rgb(0,0);">),102);">CCFadeOut</span><span class="pun" style="color: rgb(102,0);"> callfuncN_selector</span><span class="pun" style="color: rgb(102,0);">callback2</span><span class="pun" style="color: rgb(102,0);">//CCCallFuncNC的使用</span><span class="pln" style="color: rgb(0,0);">  action3 </span><span class="pun" style="color: rgb(102,102);">CCRotateBy</span><span class="pun" style="color: rgb(102,102);">3</span><span class="pln" style="color: rgb(0,0);"> </span><span class="lit" style="color: rgb(0,102);">360</span><span class="pun" style="color: rgb(102,0);"> callfuncND_selector</span><span class="pun" style="color: rgb(102,0);">callback3</span><span class="pun" style="color: rgb(102,0);">*)</span><span class="lit" style="color: rgb(0,102);">0xbebabeba</span><span class="pun" style="color: rgb(102,0);">

    sprite1</span><span class="pun" style="color: rgb(102,0);">-></span><span class="pln" style="color: rgb(0,0);">runAction</span><span class="pun" style="color: rgb(102,0);">action</span><span class="pun" style="color: rgb(102,0);">
    sprite2</span><span class="pun" style="color: rgb(102,0);">action2</span><span class="pun" style="color: rgb(102,0);">
    sprite3</span><span class="pun" style="color: rgb(102,0);">action3</span><span class="pun" style="color: rgb(102,102);">CCSize</span><span class="pln" style="color: rgb(0,0);"> s </span><span class="pun" style="color: rgb(102,102);">CCDirector</span><span class="pun" style="color: rgb(102,0);">sharedDirector</span><span class="pun" style="color: rgb(102,0);">getWinSize</span><span class="pun" style="color: rgb(102,102);">CCLabelTTF</span><span class="pln" style="color: rgb(0,0);">label </span><span class="pun" style="color: rgb(102,102);">CCLabelTTF</span><span class="pun" style="color: rgb(102,0);">(</span><span class="str" style="color: rgb(0,136,0);">"callback 1 called"</span><span class="pun" style="color: rgb(102,0);"> </span><span class="str" style="color: rgb(0,0);">"Marker Felt"</span><span class="pun" style="color: rgb(102,102);">16</span><span class="pun" style="color: rgb(102,0);">
    label</span><span class="pun" style="color: rgb(102,0);">setPosition</span><span class="pun" style="color: rgb(102,0);">ccp</span><span class="pun" style="color: rgb(102,0);"> s</span><span class="pun" style="color: rgb(102,0);">width</span><span class="pun" style="color: rgb(102,0);">/</span><span class="lit" style="color: rgb(0,102);">4</span><span class="pun" style="color: rgb(102,0);">*</span><span class="lit" style="color: rgb(0,102);">1</span><span class="pun" style="color: rgb(102,0);">s</span><span class="pun" style="color: rgb(102,0);">height</span><span class="pun" style="color: rgb(102,0);">));</span><span class="pln" style="color: rgb(0,0);">

    addChild</span><span class="pun" style="color: rgb(102,0);">label</span><span class="pun" style="color: rgb(102,0);"> pSender</span><span class="pun" style="color: rgb(102,0);">"callback 2 called"</span><span class="pun" style="color: rgb(102,0);"> pTarget</span><span class="pun" style="color: rgb(102,0);">"callback 3 called"</span><span class="pun" style="color: rgb(102,102);">3</span><span class="pun" style="color: rgb(102,0);">
    addChild</span><span class="pun" style="color: rgb(102,0);">}</span>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


    本文实践自 RayWenderlich、Ali Hafizji 的文章《How To Create Dynamic Textures with CCRenderTexture in Cocos2D 2.X》,文中使用Cocos2D,我在这里使用Cocos2D-x 2.1.4进行学习和移植。在这篇文章,将会学习到如何创建实时纹理、如何用Gimp创建无缝拼接纹
Cocos-code-ide使用入门学习地点:杭州滨江邮箱:appdevzw@163.com微信公众号:HopToad 欢迎转载,转载标注出处:http://blog.csdn.netotbaron/article/details/424343991.  软件准备 下载地址:http://cn.cocos2d-x.org/download 2.  简介2.1         引用C
第一次開始用手游引擎挺激动!!!进入正题。下载资源1:从Cocos2D-x官网上下载,进入网页http://www.cocos2d-x.org/download,点击Cocos2d-x以下的Download  v3.0,保存到自定义的文件夹2:从python官网上下载。进入网页https://www.python.org/downloads/,我当前下载的是3.4.0(当前最新
    Cocos2d-x是一款强大的基于OpenGLES的跨平台游戏开发引擎,易学易用,支持多种智能移动平台。官网地址:http://cocos2d-x.org/当前版本:2.0    有很多的学习资料,在这里我只做为自己的笔记记录下来,错误之处还请指出。在VisualStudio2008平台的编译:1.下载当前稳
1.  来源 QuickV3sample项目中的2048样例游戏,以及最近《最强大脑》娱乐节目。将2048改造成一款挑战玩家对数字记忆的小游戏。邮箱:appdevzw@163.com微信公众号:HopToadAPK下载地址:http://download.csdn.net/detailotbaron/8446223源码下载地址:http://download.csdn.net/
   Cocos2d-x3.x已经支持使用CMake来进行构建了,这里尝试以QtCreatorIDE来进行CMake构建。Cocos2d-x3.X地址:https://github.com/cocos2d/cocos2d-x1.打开QtCreator,菜单栏→"打开文件或项目...",打开cocos2d-x目录下的CMakeLists.txt文件;2.弹出CMake向导,如下图所示:设置
 下载地址:链接:https://pan.baidu.com/s/1IkQsMU6NoERAAQLcCUMcXQ提取码:p1pb下载完成后,解压进入build目录使用vs2013打开工程设置平台工具集,打开设置界面设置: 点击开始编译等待编译结束编译成功在build文件下会出现一个新文件夹Debug.win32,里面就是编译
分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!http://www.captainbed.net前言上次用象棋演示了cocos2dx的基本用法,但是对cocos2dx并没有作深入的讨论,这次以超级马里奥的源代码为线索,我们一起来学习超级马里奥的实
1. 圆形音量button事实上作者的本意应该是叫做“电位计button”。可是我觉得它和我们的圆形音量button非常像,所以就这么叫它吧~先看效果:好了,不多解释,本篇到此为止。(旁白: 噗。就这样结束了?)啊才怪~我们来看看代码:[cpp] viewplaincopyprint?CCContro
原文链接:http://www.cnblogs.com/physwf/archive/2013/04/26/3043912.html为了进一步深入学习贯彻Cocos2d,我们将自己写一个场景类,但我们不会走的太远,凡是都要循序渐进,哪怕只前进一点点,那也至少是前进了,总比贪多嚼不烂一头雾水的好。在上一节中我们建
2019独角兽企业重金招聘Python工程师标准>>>cocos2d2.0之后加入了一种九宫格的实现,主要作用是用来拉伸图片,这样的好处在于保留图片四个角不变形的同时,对图片中间部分进行拉伸,来满足一些控件的自适应(PS: 比如包括按钮,对话框,最直观的形象就是ios里的短信气泡了),这就要求图
原文链接:http://www.cnblogs.com/linji/p/3599478.html1.环境和工具准备Win7VS2010/2012,至于2008v2版本之后似乎就不支持了。 2.安装pythonv.2.0版本之前是用vs模板创建工程的,到vs2.2之后就改用python创建了。到python官网下载版本2.7.5的,然后
环境:ubuntu14.04adt-bundle-linux-x86_64android-ndk-r9d-linux-x86_64cocos2d-x-3.0正式版apache-ant1.9.3python2.7(ubuntu自带)加入环境变量exportANDROID_SDK_ROOT=/home/yangming/adt-bundle-linux/sdkexportPATH=${PATH}:/$ANDROID_SDK_ROOTools/export
1开发背景游戏程序设计涉及了学科中的各个方面,鉴于目的在于学习与进步,本游戏《FlappyBird》采用了两个不同的开发方式来开发本款游戏,一类直接采用win32底层API来实现,另一类采用当前火热的cocos2d-x游戏引擎来开发本游戏。2需求分析2.1数据分析本项目要开发的是一款游
原文链接:http://www.cnblogs.com/linji/p/3599912.html//纯色色块控件(锚点默认左下角)CCLayerColor*ccc=CCLayerColor::create(ccc4(255,0,0,128),200,100);//渐变色块控件CCLayerGradient*ccc=CCLayerGradient::create(ccc4(255,0,0,
原文链接:http://www.cnblogs.com/linji/p/3599488.html//载入一张图片CCSprite*leftDoor=CCSprite::create("loading/door.png");leftDoor->setAnchorPoint(ccp(1,0.5));//设置锚点为右边中心点leftDoor->setPosition(ccp(240,160));/
为了答谢广大学员对智捷课堂以及关老师的支持,现购买51CTO学院关老师的Cocos2d-x课程之一可以送智捷课堂编写图书一本(专题可以送3本)。一、Cocos2d-x课程列表:1、Cocos2d-x入门与提高视频教程__Part22、Cocos2d-x数据持久化与网络通信__Part33、Cocos2d-x架构设计与性能优化内存优
Spawn让多个action同时执行。Spawn有多种不同的create方法,最终都调用了createWithTwoActions(FiniteTimeAction*action1,FiniteTimeAction*action2)方法。createWithTwoActions调用initWithTwoActions方法:对两个action变量初始化:_one=action1;_two=action2;如果两个a
需要环境:php,luajit.昨天在cygwin上安装php和luajit环境,这真特么是一个坑。建议不要用虚拟环境安装打包环境,否则可能会出现各种莫名问题。折腾了一下午,最终将环境转向linux。其中,luajit的安装脚本已经在quick-cocos2d-x-develop/bin/中,直接luajit_install.sh即可。我的lin
v3.0相对v2.2来说,最引人注意的。应该是对触摸层级的优化。和lambda回调函数的引入(嗯嗯,不枉我改了那么多类名。话说,每次cocos2dx大更新。总要改掉一堆类名函数名)。这些特性应该有不少人研究了,所以今天说点跟图片有关的东西。v3.0在载入图片方面也有了非常大改变,仅仅只是