【深入了解cocos2d-x 3.x】定时器(scheduler)的使用和原理探究(1)

【深入了解cocos2d-x 3.x】定时器(scheduler)的使用和原理探究(1),第1张

概述注:本文开始,引擎升级到cocos2dx 3.6 在游戏开发过程中,经常会遇到使用计时器的情况,例如:倒计时,定时炸d等。scheduler是cocos2dx 2.x时代就已经存在的产物,主要用于各种延时函数以及各种每帧运行的函数。本文主要介绍scheduler的API函数以及使用方法。 首先,所有继承Node的类都可以使用scheduler,以下是Node类下相关API的介绍 /**

注:本文开始,引擎升级到cocos2dx 3.6

在游戏开发过程中,经常会遇到使用计时器的情况,例如:倒计时,定时炸d等scheduler是cocos2dx 2.x时代就已经存在的产物,主要用于各种延时函数以及各种每帧运行的函数。本文主要介绍scheduler的API函数以及使用方法。

首先,所有继承Node的类都可以使用scheduler,以下是Node类下相关API的介绍

    /**     * 开启自带的update方法,这个方法会每帧执行一次,默认优先级为0,并且在所有自定义方法执行之前执行     */    voID scheduleUpdate(voID);    /**     * 开启自带的update方法,这个方法会每帧执行一次,设定的优先级越小,越优先执行     */    voID scheduleUpdateWithPriority(int priority);    /**     * 关闭自带的update方法     */    voID unscheduleUpdate(voID);    /**     * 定义一个自定义的定时器	 * selector:回调函数	 * interval:重复间隔时间,重复执行间隔的时间,如果传入0,则表示每帧调用	 * repeat:重复运行次数,如果传入CC_REPEAT_FOREVER则表示无限循环	 * delay:延时秒数,延迟delay秒开始执行第一次回调     */    voID schedule(SEL_SCHEDulE selector,float interval,unsigned int repeat,float delay);    /**	 * 定义一个立即执行的无限循环的自定义定时器	 * interval:重复间隔时间,重复执行间隔的时间,如果传入0,则表示每帧调用     */    voID schedule(SEL_SCHEDulE selector,float interval);    /**     * 定义一个延迟执行的单次自定义定时器     * delay:延时秒数,延迟delay秒开始执行第一次回调     */    voID scheduleOnce(SEL_SCHEDulE selector,float delay);    /**     * 定义了一个无限循环、立即执行并且每帧都会执行的自定义定时器(和scheduleUpdate效果一样,但是会在scheduleUpdate之后执行)     */    voID schedule(SEL_SCHEDulE selector);	 /**     * 使用lambda函数定义一个每帧调用的自定义定时器     * callback:lambda函数     * key:lambda函数的Key,用于取消定时器     */    voID schedule(const std::function<voID(float)>& callback,const std::string &key);    /**     * 使用lambda函数定义一个每隔interval秒调用的自定义定时器     * callback:lambda函数	 * interval:重复间隔时间,重复执行间隔的时间,如果传入0,则表示每帧调用     * key:lambda函数的Key,用于取消定时器     */    voID schedule(const std::function<voID(float)>& callback,const std::string &key);    /**     * 使用lambda函数定义一个自定义定时器     * callback:lambda函数	 * interval:重复间隔时间,重复执行间隔的时间,如果传入0,则表示每帧调用	 * repeat:重复运行次数,如果传入CC_REPEAT_FOREVER则表示无限循环	 * delay:延时秒数,延迟delay秒开始执行第一次回调     * key:lambda函数的Key,用于取消定时器     * @lua NA     */    voID schedule(const std::function<voID(float)>& callback,float delay,const std::string &key);	    /**     * 取消一个自定义定时器     */    voID unschedule(SEL_SCHEDulE selector);    /**     * 取消本节点上所有的定时器(包括scheduleUpdate开启的定时器)     */    voID unscheduleAllSelectors(voID);


接下来用一个简单的倒计时例子来学习API的使用,首先看看实现效果:


具体代码如下:

bool HelloWorld::init(){    if ( !Layer::init() )    {        return false;    }	//int _time;	//Label *_countdownLabel; //类成员变量	_time = 10;	_countdownLabel = Label::create(String::createWithFormat("%d",_time)->getCString(),"微软雅黑",24);	_countdownLabel->setposition(Vec2(200,200));	addChild(_countdownLabel);	//方法1	//schedule(schedule_selector(HelloWorld::NextTime),1.f,CC_REPEAT_FOREVER,0.0f);	//方法2	schedule([&](float dt)	{		if (_time == 0)		{			unschedule("CountDown");			_countdownLabel->setString("end");		}		else		{			--_time;			_countdownLabel->setString(String::createWithFormat("%d",_time)->getCString());		}	},0.0f,"CountDown");	return true;}voID HelloWorld::NextTime(float dt){	if (_time == 0)	{		unschedule(schedule_selector(HelloWorld::NextTime));		_countdownLabel->setString("end");	}	else	{		--_time;		_countdownLabel->setString(String::createWithFormat("%d",_time)->getCString());	}}


方法1与方法2实现的效果完全一样,区别在于一个使用了Lambda函数,一个使用了传统的方法。


接下来简单说一下scheduleOnce,这个函数用于延时执行,比如可以实现2秒后删除自身,具体代码如下:

	scheduleOnce([this](float dt)	{		this->removeFromParent();	},2.f,"Del");

scheduleOnce是一个非常有用的函数,在很多场合都会用到。

然后再来看看scheduleUpdate,这是一个与其他函数有所区别,启动的是一个Node::update方法,启动之后这个方法每帧执行,而且会优先于自定义计时器执行,也可以指定优先级。

接下来我们想实现一个移动动画,每秒钟固定向左边移动一定的距离,通过scheduleUpdate实现,以下是实现代码:

bool HelloWorld::init(){    if ( !Layer::init() )    {        return false;    }	_moveX = 100.0f;	scheduleUpdate();}voID HelloWorld::update(float dt){	float moveX = _moveX * dt;	_countdownLabel->setpositionX(_countdownLabel->getpositionX() + moveX);}
本文通过一些基础的定时器应用分析了cocos2dx中scheduler的基本使用方法,在项目中会有更多定时器的应用场景。下一篇文章将对创建定时器的实现进行分析。 总结

以上是内存溢出为你收集整理的【深入了解cocos2d-x 3.x】定时器(scheduler)的使用和原理探究(1)全部内容,希望文章能够帮你解决【深入了解cocos2d-x 3.x】定时器(scheduler)的使用和原理探究(1)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1059646.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存