加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

cocos2d-js浅谈schedule的用法

发布时间:2020-12-14 17:11:23 所属栏目:百科 来源:网络整理
导读:展性及实用性上,建议大家统一使用cocos2d自身提供的schedule方法。下面就为大家深入浅出的介绍下schedule: 一、schedule 有三种不同的api: 1. scheduleUpdate(): 2.scheduleOnce(callback,delay,key): Parameters: {function} callback A function wrapp
展性及实用性上,建议大家统一使用cocos2d自身提供的schedule方法。下面就为大家深入浅出的介绍下schedule:

一、schedule 有三种不同的api:

1. scheduleUpdate():

2.scheduleOnce(callback,delay,key):

Parameters:

{function} callback

A function wrapped as a selector

{Number} delay

The amount of time that the first tick will wait before execution.

{String} key

The only string identifying the callback

3. schedule(callback,interval,repeat,key):

Parameters:

{function} callback

A function wrapped as a selector

{Number} interval

Tick interval in seconds. 0 means tick every frame. If interval = 0,it's recommended to use scheduleUpdate() instead.

{Number} repeat

The selector will be executed (repeat + 1) times,you can use kCCRepeatForever for tick infinitely.

{Number} delay

The amount of time that the first tick will wait before execution.

{String} key

The only string identifying the callback


二、schedule三种api的使用:

1. scheduleUpdate()

以layer为例,在初始化的时候(ctor函数return true 前,其他地方也可以,建议在初始化时)添加:

[javascript] view plain copy
  1. this.scheduleUpdate();//开启每帧调用,对应update
接着重写layer的update方法:(这里先定义了一个layer的成员变量time)
[javascript] view plain copy
  1. update:function(dt){
  2. this.time+=dt;//dt为上一帧到当前帧的时长
  3. if(this.time>=3){
  4. cc.log("每3秒在调试框中输出一次");
  5. this.time=0;
  6. };
  7. },

2.scheduleOnce(callback,key)

以layer为例,在初始化或其他非解析方法内添加:

[javascript] view plain copy
  1. //延迟2秒后,只执行一次
  2. this.scheduleOnce(this.once,2);
接着新建一个once的方法:
[javascript] view plain copy
  1. once:function(){
  2. cc.log("延迟2秒后,只执行一次");
  3. },

3.schedule(callback,key)

同样以layer为例,在初始化或其他非解析方法内添加:

[javascript] view plain copy
  1. //不带参数的回调函数notParameter,延迟5秒后每2秒执行一次,累积执行20次
  2. bsp;this.schedule(this.notParameter,2,20,5);
接着新建一个notParameter的方法:
[javascript] view plain copy
  1. notParameter:function(){
  2. cc.log("不带参数的回调函数notParameter,延迟5秒后每2秒执行一次,累积执行20次");
  3. },

三、schedule的代码示例:

[javascript] view plain copy
  1. vartest=cc.Layer.extend({
  2. time:0,
  3. ctor:function(){
  4. this._super();
  5. this.time=0;
  6. this.scheduleUpdate();//开启每帧调用,对应update
  7. //不带参数的回调函数notParameter,延迟5秒后每2秒执行一次,累积执行20次
  8. this.schedule(this.notParameter,5);
  9. //带参数的回调函数haveParameter,每1.5秒执行一次,累积执行10次
  10. this.schedule(functionnothing(){
  11. this.haveParameter("带参数")
  12. },1.5,10);
  13. //每5秒执行一次,无次数限制
  14. this.schedule(this.notRepeat,5);
  15. //延迟2秒后,只执行一次
  16. this.scheduleOnce(this.once,2);
  17. returntrue;
  18. },
  19. notRepeat:function(){
  20. cc.log("每5秒执行一次");
  21. },
  22. notParameter:function(){
  23. cc.log("不带参数的回调函数notParameter,延迟5秒后每2秒执行一次,累积执行20次");
  24. },
  25. haveParameter:function(s){
  26. cc.log(s+"的回调函数haveParameter,每1.5秒执行一次,累积执行10次");
  27. },
  28. once:function(){
  29. cc.log("延迟2秒后,只执行一次");
  30. },
  31. update:function(dt){
  32. this.time+=dt;//dt为上一帧到当前帧的时长
  33. if(this.time>=3){
  34. cc.log("每3秒在调试框中输出一次");
  35. this.time=0;
  36. };
  37. },
  38. onExit:function(){
  39. this._super();
  40. this.unscheduleUpdate();//移除schedule
  41. this.unschedule(this.notRepeat);//移除没有次数限制的schedule
  42. this.unscheduleAllCallbacks();//移除所有schedule的回调函数
  43. }
  44. });

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读