cocos2dx三种定时器的使用以及停止schedule。scheduleUpdate。scheduleOnce

今天白白跟大家分享一下cocos2dx中定时器的用法。

首先,什么是定时器呢?也许你有时候会想让某个函数不断的去运行。也许仅仅是运行一次,获取你想让他每隔几秒运行一次。ok。这些都能够统统交给定时器来解决。

cocos2dx中有三种定时器:schedule,scheduleUpdate。scheduleOnce。了解其功能便会发现定时器真是太方便了,废话不多说,我们逐一学习一下。

1、scheduleUpdate

增加当前节点后,程序会每帧都会自己主动运行一次默认的Update函数。

(注:一定是Update函数哦,若想调用其它自己命名的函数则使用schedule)

看样例,走起。

首先在HelloWord类的头文件里声明Update函数:

  1. void Update(float dt);   //注意參数类型
void Update(float dt);   //注意參数类型

然后在HelloWorld类源文件里实现函数Update:

  1. void HelloWorld::Update(float dt)
  2. {
  3. CCLOG("baibai");
  4. }
void HelloWorld::Update(float dt)
{
CCLOG("baibai");
}

如今我们能够调用了。在须要他不断运行的地方增加调用的代码就ok:

  1. this->scheduleUpdate();     //this是当前节点。如layer,所以能够省略啦。
this->scheduleUpdate();     //this是当前节点,如layer,所以能够省略啦。

执行之后你将会看到不断有baibai被打印出来

2、scheduleUpdate

能够没隔几秒运行某个自己定义的函数,来看代码:

首先还是在HelloWorld中声明所要运行的函数:

  1. void Move(float dt);
void Move(float dt);

然后在源文件实现:

  1. void HelloWorld::Move(float dt)
  2. {
  3. CCLOG("baibai");
  4. }
void HelloWorld::Move(float dt)
{
CCLOG("baibai");
}

如今去运行他。注意參数哦

  1. scheduleOnce(schedule_selector(HelloWorld::Move), 1.0f);//每隔1.0f运行一次。省略參数则表示每帧都要运行
scheduleOnce(schedule_selector(HelloWorld::Move), 1.0f);//每隔1.0f运行一次,省略參数则表示每帧都要运行

执行之后。baibai每隔1.0f才会被打印一次。

3、scheduleOnce

功能:在几秒之后运行,而且仅仅运行一次。

我们就运行上面所写过的Move函数吧:

  1. scheduleOnce(schedule_selector(HelloWorld::Move), 1.0f); //在1.0f之后运行,而且仅仅运行一次。

scheduleOnce(schedule_selector(HelloWorld::Move), 1.0f); //在1.0f之后运行,而且仅仅运行一次。

执行一下,baibai仅仅是被打印了一次就完了。。。

ok,定时器的调用已经讲完,大家最好还是自己写一些函数体验一下。

可是怎么让定时器停止呢?

1、停止运行自定义函数的定时器:

  1. this->unschedule(schedule_selector(HelloWorld::Move));
this->unschedule(schedule_selector(HelloWorld::Move));

2、停止默认定时器:

  1. this->unscheduleUpdate();
this->unscheduleUpdate();

3、停止全部定时器:

  1. this->unscheduleAllSelectors();
this->unscheduleAllSelectors();

1.概况

CCNode内部封装了一个

  1. CCScheduler *m_pScheduler;

正是通过它我们能够非常轻松地完毕一些定时功能,所以定时器是节点所具备的功能。

定时器分为2种,一种是更新定时器,运行的频率是每帧运行一次,还有一种则是自己定义回调函数的定时器(最小值是一帧)。关于回调函数和函数指针的相关基础可參见http://blog.csdn.net/jackystudio/article/details/11720325

2.API

  1. //更新定时器,每帧调用1次。每一个节点仅仅能有1个被调度的update函数
  2. void
    scheduleUpdate(void);
  3. //卸载更新定时器
  4. void
    unscheduleUpdate(void);
  5. //自己定义定时器,假设反复调用,那调用间隔会更新。而不会再次调用
  6. //interval,调用时间间隔,假设为0,建议使用scheduleUpdate
  7. //repeat,回调函数会被运行repeat+1次,kCCRepeatForever是无限次调用
  8. //delay。第一次运行前的延时
  9. void
    schedule(SEL_SCHEDULE selector, float
    interval, unsigned int
    repeat, float
    delay);
  10. void
    schedule(SEL_SCHEDULE selector, float
    interval);
  11. void
    scheduleOnce(SEL_SCHEDULE selector, float
    delay);
  12. void
    schedule(SEL_SCHEDULE selector);
  13. //卸载自己定义定时器
  14. void
    unschedule(SEL_SCHEDULE selector);
  15. void
    unscheduleAllSelectors(void);
  16. //恢复全部定时器和动作,OnEnter调用
  17. void
    resumeSchedulerAndActions(void);
  18. //暂停全部定时器和动作,OnExit调用
  19. void
    pauseSchedulerAndActions(void);
  20. //scheduleUpdate每帧调用
  21. virtual
    void
    update(float
    delta);

3.演示样例

3.1.更新定时器

  1. //开启定时器
  2. this->scheduleUpdate();
  3. //虚函数update
  4. void
    HelloWorld::update(float
    delta)
  5. {
  6. CCLog("%f",delta);
  7. }
  8. //输出,这里设置了60fps,调用间隔1/60s
  9. 0.016667
  10. 0.016676
  11. 0.016657
  12. 0.016669

3.2.自己定义定时器

  1. //开启定时器,延时2s运行,运行3+1次,运行间隔1s
  2. this->schedule(schedule_selector(HelloWorld::log),1,3,2);
  3. //回调函数
  4. void
    HelloWorld::log(float
    dt)
  5. {
  6. CCLog("schedule");
  7. }
  8. //输出
  9. 2.004532
  10. 1.005827
  11. 1.000238
  12. 1.001019

4.schedule_selector和SEL_SCHEDULE

看到上面的schedule_selector了吧。这又是个什么玩意?看看它的宏定义。

  1. #define
    schedule_selector(_SELECTOR) (SEL_SCHEDULE)(&_SELECTOR)

原来是把函数指针转化为SEL_SCHEDULE型指针,那SEL_SCHEDULE又是什么?

  1. typedef
    void
    (CCObject::*SEL_SCHEDULE)(float);

也没啥,就是定义了一个带有float參数函数指针。所以我们在使用自己定义Schedule的时候,回调函数一定要记得带上一个float參数。它记录了两次运行的间隔。

假设忘了。但是会出现类型转换错误的异常。这样的方式在callfunc_selector,menu_selector等也以相同的方式出现。

5.谁来调用回调函数

但是有没有发现,假设这个回调函数是个全局函数或者static函数也就算了,偏偏它是个成员函数,成员函数须要实例来调用,但是从调用方法来看。好像没传入调用对象?

  1. this->schedule(schedule_selector(HelloWorld::log),1,3,2);

是的。还记得一开头说的CCNode内部封装的m_pScheduler吗?

  1. CCScheduler *m_pScheduler;

原来CCNode帮我们实现了:

  1. void
    CCNode::schedule(SEL_SCHEDULE selector, float
    interval, unsigned int
    repeat, float
    delay)
  2. {
  3. CCAssert(
    selector, "Argument must
    be non-nil");
  4. CCAssert(
    interval >=0, "Argument
    must be positive");
  5. m_pScheduler->scheduleSelector(selector,
    this,
    interval , repeat, delay, !m_bRunning);
  6. }

原来this这个时候被传入了,同一时候传入的參数还有m_bRunning,m_bRunning表示节点是否在执行中(是否在舞台上)。OnEnter的时候赋值true,OnExit的时候赋值false。所以在执行定时器的时候还必须确保节点有在执行。

这样确有用起来怪怪的。所以在cocos2d-x v3.0版本号中,參数和函数指针用一个宏打包起来了~

至于CCSchedule内部是怎么实现的,以及CCTimer的触发回调,有兴趣的就自己看看源代码吧

版权声明:本文博主原创文章,博客,未经同意不得转载。

cocos2dx三种定时器使用的更多相关文章

  1. cocos2dx三种定时器的使用以及停止schedule,scheduleUpdate,scheduleOnce。

    今天白白跟大家分享一下cocos2dx中定时器的使用方法. 首先,什么是定时器呢?或许你有时候会想让某个函数不断的去执行,或许只是执行一次,获取你想让他每隔几秒执行一次,ok,这些都可以统统交给定时器 ...

  2. Objective-C三种定时器CADisplayLink / NSTimer / GCD的使用

    OC中的三种定时器:CADisplayLink.NSTimer.GCD 我们先来看看CADiskplayLink, 点进头文件里面看看, 用注释来说明下 @interface CADisplayLin ...

  3. C#中三种定时器对象的比较 【转】

    https://www.cnblogs.com/zxtceq/p/5667281.html C#中三种定时器对象的比较 ·关于C#中timer类 在C#里关于定时器类就有3个1.定义在System.W ...

  4. C#中三种定时器对象的比较

    ·关于C#中timer类 在C#里关于定时器类就有3个1.定义在System.Windows.Forms里2.定义在System.Threading.Timer类里3.定义在System.Timers ...

  5. C#三种定时器

    三个定时器分别是 实现按用户定义的时间间隔引发事件的计时器.此计时器最宜用于 Windows 窗体应用程序中,并且必须在窗口中使用. System.Windows.Forms.Timer 提供以指定的 ...

  6. C#三种定时器的实现

    http://www.coridc.com/archives/2253.html c#中提供了三种类型的计时器: 1.基于 Windows 的标准计时器(System.Windows.Forms.Ti ...

  7. iOS三种定时器的用法NSTimer、CADisplayLink、GCD

    一,NSTimer //创建方式1 NSTimer *timer = [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector: ...

  8. NSTimer、CADisplayLink、GCD 三种定时器的用法 —— 昉

    在软件开发过程中,我们常常需要在某个时间后执行某个方法,或者是按照某个周期一直执行某个方法.在这个时候,我们就需要用到定时器. 在iOS中有很多方法完成定时器的任务,例如 NSTimer.CADisp ...

  9. android 三种定时器的写法

    //两秒后执行new Handler().postDelayed(new Runnable() { @Override public void run() { --todo }}, 2000); -- ...

随机推荐

  1. nginx源代码分析--高性能server开发 常见的流程模型

    1.高性能server 对于高性能server对于.处理速度和占用空间小是典型特性.特别是当server经验C10K问题的时候(网络server在处理数以万计的client连接时.往往出现效率低下甚至 ...

  2. Java读取本地文件,并显示在JSP文件中

        当我们初学IMG标签时,我们知道通过设置img标签的src属性,能够在页面中显示想要展示的图片.其中src的值,可以是磁盘目录上的绝对,也可以是项目下的相对路径,还可以是网络上的图片路径.在存 ...

  3. STL中vector的赋值,遍历,查找,删除,自定义排序——sort,push_back,find,erase

    今天学习网络编程,那个程序中利用了STL中的sort,push_back,erase,自己没有接触过,今天学习一下,写了一个简单的学习程序.编译环境是VC6.0         这个程序使用了vect ...

  4. 【从翻译mos文章】SGA_TARGET与SHMMAX关系

    SGA_TARGET与SHMMAX关系 参考原始: Relationship Between SGA_TARGET and SHMMAX (文件 ID 1527109.1) 申请: Oracle Da ...

  5. hdu3038(并查集)

    题目链接 题意:有n次询问,给出a到b区间的总和,问这n次给出的总和中有几次是和前面已近给出的是矛盾的 分析:sum数组维护着到根节点的距离(即区间和),每次合并x,y,s(a,b分别为x,y的根节点 ...

  6. poj1797(最短路小变形)

    题目连接:http://poj.org/problem?id=1797 题意: 分析:dp[i]表示到达i点的过程中的最大承受重量,更新到i点时可能有多条路径,由优先队列堆出最大的那条即可. #inc ...

  7. leetcode 之 Permutation Sequence

    Permutation Sequence The set [1,2,3,-,n] contains a total of n! unique permutations. By listing and ...

  8. PPTP和L2TP的区别

    PPTP是点到点的隧道协议,服务器端使用TCP 的1723端口,同时使用GRE协议,加密上使用MPPE.位于NAT后的客户端连接会有问题. L2TP是二层隧道VPN,使用IPsec 进行加密,服务器端 ...

  9. cocoapod安装失败解决

    cocoapods 是 iOS 上不错的包依赖管理软件,在前面的文章里衣服自己洗是有做简单的介绍.最近在学习iOS开发,中间碰到安装cocoapods一些问题,具体的安装教程网上非常多,大家搜一下久可 ...

  10. Java的图片处理工具类

    import Java.awt.AlphaComposite; import java.awt.Color; import java.awt.Font; import java.awt.Graphic ...