1
缓冲动作

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

man->setScale(0.8f);

woman->setScale(0.8f);

man->setPosition(ccp(100, 80));

woman->setPosition(ccp(100,240));

CCMoveTo * manTo = CCMoveTo::create(2, ccp(400,80));

CCMoveTo * womanTo = CCMoveTo::create(2, ccp(400, 240));

CCEaseExponentialIn *in = CCEaseExponentialIn::create(manTo);

CCEaseExponentialOut *out = CCEaseExponentialOut::create(manTo);

CCEaseExponentialInOut * inOut =

CCEaseExponentialInOut::create(manTo);

man->runAction(inOut);

woman->runAction(womanTo);

CCEaseElasticIn *in = CCEaseElasticIn::create(manTo);

CCEaseElasticOut *out = CCEaseElasticOut::create(manTo);

CCEaseElasticInOut * inOut = CCEaseElasticInOut::create(manTo);

#include
"T13Action.h"

#include
"AppMacros.h"

CCScene *T13Action::scene()

{

CCScene *
scene =
CCScene::create();

T13Action *
layer =
T13Action::create();

scene->addChild(layer);

return
scene;

}

bool
T13Action::init()

{

TBack::init();

CCSprite *
man =
CCSprite::create("man.png");

CCSprite *
woman =
CCSprite::create("woman.png");

man->setPosition(ccp(100,
160));

CCMoveBy *by
= CCMoveBy::create(2,ccp(300,0));

CCMoveBy
*by2
= CCMoveBy::create(2,ccp(300,0));

CCEaseExponentialIn * in =
CCEaseExponentialIn::create(by2);

CCEaseExponentialInOut
* out =
CCEaseExponentialInOut::create(by2);

CCEaseExponentialInOut *
inOut =
CCEaseExponentialInOut::create(by2);

//CCEaseElasticIn * in = CCEaseElasticIn::create(by2);

//CCEaseElasticOut * out = CCEaseElasticOut::create(by2);

//CCEaseElasticInOut * inOut = CCEaseElasticInOut::create(by2);

//CCEaseBounceIn 
*in = CCEaseBounceIn::create(by2);

//CCEaseBounceOut * out = CCEaseBounceOut::create(by2);

//CCEaseBounceInOut * inOut = CCEaseBounceInOut::create(by2);

//看精灵的执行速度

//man->runAction(in);

//man->runAction(out);

man->runAction(inOut);

addChild(man);

return
true;

}

//原生画图,每一帧都会画图

void
T13Action::draw()

{

CCPointArray *array =
CCPointArray::create(6);

array->addControlPoint(ccp(100,
160));

array->addControlPoint(ccp(200,
160));

array->addControlPoint(ccp(200,
250));

array->addControlPoint(ccp(300,
250));

array->addControlPoint(ccp(300,
160));

array->addControlPoint(ccp(450,
160));

ccDrawCardinalSpline(array, 1, 100);

}

执行结果:

2
并行动作和序列动作

CCSequence
中持续时间为全部动作累计的总合。CCSequence
中不能够

有CCRepeatForever
动作。

CCSpwan中持续时间为并行动作持续时间最长的决定。

3
假动作

CCCallFunc系列动作包含CCallFunc()、CCCallFuncN()、CCCallFuncND,以及CCCallFuncO四个动作,CCCallFunc系列动作的后缀”N”表示Node參数,指的是运行动作的对象,”D”表示Data參数,指的是用户自己定义的数据。”O”表示对象,指的是一个用户自己定义的CCObject參数。

在不同的情况下。我们能够依据不同的需求来选择不同的CCCallFunc动作。

typedef void (CCObject::*SEL_CallFunc)();

//无參类型

typedef void (CCObject::*SEL_CallFuncN)(CCNode*);

//传递CCNode *
类型变量

typedef void (CCObject::*SEL_CallFuncND)(CCNode*, void*);

//传递CCNode *
类型变量,和无类型变量

typedef void (CCObject::*SEL_CallFuncO)(CCObject*);

//传递CCObject *类型变量

#define callfunc_selector(_SELECTOR) (SEL_CallFunc)(&_SELECTOR)

#define callfuncN_selector(_SELECTOR) (SEL_CallFuncN)(&_SELECTOR)

#define callfuncND_selector(_SELECTOR) (SEL_CallFuncND)(&_SELECTOR)

#define callfuncO_selector(_SELECTOR) (SEL_CallFuncO)(&_SELECTOR)

CCCallFunc * func = CCCallFunc::create(this,

callfunc_selector(T13Action::funcCallBack));

CCCallFuncN * func = CCCallFuncN::create(this,

callfuncN_selector(T13Action::funcNCallBack));

CCCallFuncND * func = CCCallFuncND::create(this,

callfuncND_selector(T13Action::funcNDCallBack), (void *)"30");

CCArray * array = CCArray::create();

array->addObject(woman);

CCCallFuncO * func = CCCallFuncO::create(this,

callfuncO_selector(T13Action::funcOCallBack),(CCObject*)array);

CCSequence * seq = CCSequence::create(to, func, NULL);

man->runAction(seq);

addChild(man);

案例说明:

无參的假动作

void
funcCallBack();

T13Action.h

#ifndef
_T13Action_H__

#define
_T13Action_H__

#include
"cocos2d.h"

#include
"TBack.h"

USING_NS_CC;

class
T13Action :public
TBack

{

public:

static
CCScene *
scene();

CREATE_FUNC(T13Action);

bool
init();

void
draw();

//无參的假动作

void
funcCallBack();

//带调用者的假动作

void
funcNCallBack(CCNode
* node);

//带有调用者和数据的假动作

void
funcNDCallBack(CCNode
* node,
void *
data);

//带有对象的假动作

void
funcOCallBack(CCObject
* obj);

};

#endif

T13Action.cpp

#include
"T13Action.h"

#include
"AppMacros.h"

CCScene *T13Action::scene()

{

CCScene *
scene =
CCScene::create();

T13Action *
layer =
T13Action::create();

scene->addChild(layer);

return
scene;

}

bool
T13Action::init()

{

TBack::init();

CCSprite *
man =
CCSprite::create("man.png");

CCSprite *
woman =
CCSprite::create("woman.png");

man->setPosition(ccp(100,
160));

CCMoveBy *by2
= CCMoveBy::create(2,
ccp(300, 0));

//假动作就是当一个动作运行完了之后又运行的一个动作

CCCallFunc *
func =
CCCallFunc::create(this,callfunc_selector(T13Action::funcCallBack));

CCSequence *
seq =
CCSequence::create(by2,
func,
NULL);

man->runAction(seq);

addChild(man);

return
true;

}

//原生画图。每一帧都会画图

void
T13Action::draw()

{

CCPointArray *array =
CCPointArray::create(6);

array->addControlPoint(ccp(100,
160));

array->addControlPoint(ccp(200,
160));

array->addControlPoint(ccp(200,
250));

array->addControlPoint(ccp(300,
250));

array->addControlPoint(ccp(300,
160));

array->addControlPoint(ccp(450,
160));

ccDrawCardinalSpline(array, 1, 100);

}

//无參的假动作

void
T13Action::funcCallBack()
{

CCLog("action
is over");

}

执行结果(执行速度是变速的):

输出结果:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdG90b3R1enVvcXVhbg==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

4
假动作

#ifndef
_T13Action_H__

#define
_T13Action_H__

#include
"cocos2d.h"

#include
"TBack.h"

USING_NS_CC;

class
T13Action :public
TBack

{

public:

static
CCScene *
scene();

CREATE_FUNC(T13Action);

bool
init();

//无參的假动作

void
funcCallBack();

//带调用者的假动作

void
funcNCallBack(CCNode
* node);

//带有调用者和数据的假动作

void
funcNDCallBack(CCNode
* node,
void *
data);

//带有对象的假动作

void
funcOCallBack(CCObject
* obj);

};

#endif

#include
"T13Action.h"

#include
"AppMacros.h"

CCScene *T13Action::scene()

{

CCScene *
scene =
CCScene::create();

T13Action *
layer =
T13Action::create();

scene->addChild(layer);

return
scene;

}

bool
T13Action::init()

{

TBack::init();

CCSprite *
man =
CCSprite::create("man.png");

CCSprite *
woman =
CCSprite::create("woman.png");

man->setPosition(ccp(50,
160));

woman->setPosition(ccp(50,260));

//创建一个CCArray,在使用前调用retain(),要注意的是在最后退出之

//后要在onExit()中将array进行release()

CCArray * array =
CCArray::create();

array->retain();

array->addObject(woman);

CCMoveBy *by2
= CCMoveBy::create(2,
ccp(300, 0));

CCCallFuncN *
funcN =
CCCallFuncN::create(this,

callfuncN_selector(T13Action::funcNCallBack));

//调用

CCCallFuncND *funcND
= CCCallFuncND::create(this,

callfuncND_selector(T13Action::funcNDCallBack),

(void*)"30");

CCCallFuncO 
* funcO =
CCCallFuncO::create(this,

callfuncO_selector(T13Action::funcOCallBack),

array);

CCSequence *
seq =
CCSequence::create(by2,
funcO,
NULL);

man->runAction(seq);

addChild(man);

return
true;

}

//当中CCNode表示的是动作的运行者

void
T13Action::funcNCallBack(CCNode
*node)

{

CCSprite *spr
= (CCSprite *)node;

//将精灵从屏幕上

//spr->removeFromParentAndCleanup(true);

CCJumpBy *
by =
CCJumpBy::create(2,
ccp(0,0),100,1);

spr->runAction(by);

}

void
T13Action::funcNDCallBack(CCNode
* node,
void *
data)

{

CCSprite *spr
= (CCSprite *)node;

//以下是取出数据的代码

CCString *
str =
CCString::createWithFormat("%s",
(char*)data);

//给精灵旋转

spr->setRotation(str->floatValue());

}

void 
T13Action::funcOCallBack(CCObject
* obj)

{

CCArray * array = (CCArray*)obj;

//从array中取出第0个元素

CCSprite *
spr = (CCSprite*)array->objectAtIndex(0);

addChild(spr);

}

2假动作,数据缓冲,CCEaseExponential,CCEaseElastic,CCEaseBounce,CCCallFunc,funcNCallBack,funcNDCallBack,funcO的更多相关文章

  1. libevent库介绍--事件和数据缓冲

    首先在学习libevent库的使用前,我们还要从基本的了解开始,已经熟悉了epoll以及reactor,然后从event_base学习,依次学习事件event.数据缓冲Bufferevent和数据封装 ...

  2. 结构-行为-样式-Jquery实现延迟加载特效(数据缓冲特效)

    最近在做一个地产项目的过程中,原来用的延迟加载的插件在IE下会使浏览器突然缩小,这个让客户很不满意,于是就考虑到兼容性的问题决定自己写一个插件.思路:定义一个代码块,手动加载到页面,然后手动删除.   ...

  3. unix中数据缓冲区高速缓冲的设计

    目录 1. 概述 2. 缓冲区的设计 2.1 缓冲区头部 2.2 缓冲区的结构 2.3 缓冲区的检索算法 2.3. 申请一个缓冲区算法 getblk 2.3.2 释放一个缓冲区算法 brelse 2. ...

  4. oracel数据导出导入

    一.导出模式(三种模式)及命令格式 1. 全库模式 exp 用户名/密码@网络服务名 full=y file=路径\文件名.dmp log=路径\文件名.log 2. 用户模式(一般情况下采用此模式) ...

  5. Oracle 数据导入导出

    一.导出模式(三种模式)及命令格式 1. 全库模式 exp 用户名/密码@网络服务名 full=y file=路径\文件名.dmp log=路径\文件名.log 2. 用户模式(一般情况下采用此模式) ...

  6. 解决Android与服务器交互大容量数据问题

    对于目前的状况来说,移动终端的网络状况没有PC网络状况那么理想.在一个Android应用中,如果需要接收来自服务器的大容量数据,那么就不得不考虑客户的流量问题.本文根据笔者的一个项目实战经验出发,解决 ...

  7. 在VC下采用ADO实现BLOB(Binary)数据的存储,读取,修改,删除。

    在VC下采用ADO实现BLOB(Binary)数据的存储,读取,修改,删除. 作者:邵盛松 2009-09-05 前言 1关于的BLOB(Binary)数据的存储和读取功能主要参考了MSDN上的一篇& ...

  8. JAVA多线程之间共享数据BlockingQueue介绍

    在JAVA的Concurrent包中,BlockingQueue很好的解决了多线程中,如何高效安全“传输”数据的问题.通过这些高效并且线程安全的队列类,为我们快速搭建高质量的多线程程序带来极大的便利. ...

  9. MySQL数据库主键设计原则

    目录 1. 主键定义... 5 2. 主键设计原则... 5 2.1 确保主键的无意义性... 5 2.2 采用整型主键... 5 2.3 减少主键的变动... 5 2.4 避免重复使用主键... 6 ...

随机推荐

  1. ***Java多线程发展简史

    http://blog.jobbole.com/28297/ 本文来自四火的博客(@RayChase),由@_Zhijun 推荐 这篇文章,大部分内容,是周五我做的一个关于如何进行Java多线程编程的 ...

  2. HDU4535+公式

    错排公式. 用64位! /* */ #include<stdio.h> #include<string.h> #include<stdlib.h> #include ...

  3. Tomcat HTTP/1.1 Connector 参数整理

    HTTP/1.1 Connector 概述 Coyote HTTP/1.1 Connector元素是一个支持HTTP/1.1协议的Connector组件.它使Catalina除了能够执行servlet ...

  4. UDP模块(黑胶体)

    UDP模块是采用PIP封装技术的U盘半成品模块,直接加上外壳,就是成品U盘. 它有以下特点: 防水.防尘.防震. 一体WAFER封装技术. 薄.轻.时尚. 产品装配方便.简单. 产品标准化,适合客户在 ...

  5. RxJava开发精要1-从.NET到RxJava

    原文出自<RxJava Essentials> 原文作者 : Ivan Morgillo 译文出自 : 开发技术前线 www.devtf.cn 转载声明: 本译文已授权开发者头条享有独家转 ...

  6. 引用计数(retainCount)

    ClassA.h: #import <Foundation/Foundation.h> @interface ClassA:NSObject { NSString *name; } -(v ...

  7. Subline Text快捷键

    我经常使用的快捷键 Ctrl+A: 全选Ctrl+C: 复制 重复工作必备: Ctrl+D:选择单词,重复可增加选择下一个相同的单词Alt+F3:选择所有相同的词F3: 下一个Shift+F3:前一个 ...

  8. Java实现Dijkstra算法求最短路径

    任务描述:在一个无向图中,获取起始节点到所有其他节点的最短路径描述 Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到其他所有节点的最短路径.主要特点是以起始点为中心向外层 ...

  9. apache开源项目--lucence

    Lucene 是apache软件基金会一个开放源代码的全文检索引擎工具包,是一个全文检索引擎的架构,提供了完整的查询引擎和索引引擎,部分文本分析引擎.Lucene的目的是为软件开发人员提供一个简单易用 ...

  10. chrome的timeline的问题?

    如图:Stalled.RequestSent等所表达的是什么意思呢? Stalled是浏览器得到要发出这个请求的指令,到请求可以发出的等待时间,一般是代理协商.以及等待可复用的TCP连接释放的时间,不 ...