***************************************转载请注明出处:http://blog.csdn.net/lttree********************************************

啊哈~,做完这个開始准备做一些真正的小游戏耍一耍咯~

打地基,非常重要,地基打好了。能够開始别的东东啦    ~\(≧▽≦)/~啦啦啦

这次学习的东东,是计划任务,顾名思义。不须要自己动手,它自己依照一定顺序运行的东东。

最常见的,就是非常多手游里的一些開始界面中,动态的背景。

在上一次学习中。学习了屏幕触摸和消息分发机制。

最后实现了,我们触摸屏幕。然后精灵会移动到所触摸的位置。

而这次,要实现的就是,让角色自己,从左向右运动(重复)。

在cocos2d-x中,有一个大循环。它以每秒60帧的速度,不断刷新屏幕。

而我们要加入自己的计划任务,就须要利用它的这个频率,将我们自己的任务加入的这个大循环中。

首先,制定自己的更新函数,

在HelloWorldScene.h中加入update函数:

// for schedule
void update( float t );

然后在.cpp中制定动作。

我们的动作就是让 精灵 从左向右移动,就是用setPosition就能够了,

重复移动,就是加一个推断语句,大于右面边界则 从最左面又一次開始移动。

void HelloWorld::update( float t )
{
auto sprite=this->getChildByTag(33);
sprite->setPositionX(sprite->getPositionX()+1);
// 详细大于多少,看你屏幕宽度为多少啦~
if( sprite->getPositionX() > 960 )
sprite->setPositionX(0);
}

最后,别忘了,在init函数中,增加计划任务哟~

// 加入计划任务
this->scheduleUpdate(); //加入update任务

这样。执行一下,就能够发现。

不用自己触摸屏幕,你的精灵能够,慢慢从中间移动到右面,再从左面移动到右面,

为什么開始是从中间移动到右面呢?

BUG?!  NO。!

由于我们设置精灵。初始位置是在正中间呀~

OK,做到这。你能够发现,我们的频率是固定的。那...我们能控制移动的速度吗?

Of  Course!

方法一:

简单点。设置一个计数变量,

我们能够在类中,定义一个计数变量 js ,

然后,每次调用update函数的时候。js++

仅仅要js<10 ,则返回,不运行以下的语句,

当js==10时,则能够继续运行,最后让js归于0。

通过上述控制。我们能够将 每秒60速度。降到 每秒6的速度:

( 不止要在.h文件声明 js 变量。也要在Init函数中初始化为0 哟)

void HelloWorld::update( float t )
{
++js;
if( js<10 ) return; auto sprite=this->getChildByTag(33);
sprite->setPositionX(sprite->getPositionX()+1);
// 详细大于多少。看你屏幕宽度为多少啦~
if( sprite->getPositionX() > 960 )
sprite->setPositionX(0);
js=0;
}

方法二:

自带方法:

schedule(schedule_selector(_SELECTOR),float time);

两个參数,第一个就是调用哪个函数。第二个就是每隔多长时间调用。

this->schedule(schedule_selector(HelloWorld::update),1);
void HelloWorld::update( float t )
{
auto sprite=this->getChildByTag(33);
sprite->setPositionX(sprite->getPositionX()+1);
// 详细大于多少,看你屏幕宽度为多少啦~
if( sprite->getPositionX() > 960 )
sprite->setPositionX(0);
}

这样。每隔1秒。调用一次update函数,当然你也能够换一个函数调用。

and。还有关于计划任务的其它选项:

——启动

——暂停

——停止

——恢复

这些在  cocos2d-x提供的測试程序中有具体用法。这里就先不说啦~

恩,Today,就到这里吧!

(要熄灯啦~╭(╯3╰)╮)

***************************************转载请注明出处:http://blog.csdn.net/lttree********************************************

Cocos2d-x 3.0 Schedule in Node的更多相关文章

  1. 高屋建瓴 cocos2d-x-3.0架构设计 Cocos2d (v.3.0) rendering pipeline roadmap(原文)

    Cocos2d (v.3.0) rendering pipeline roadmap Why (the vision) The way currently Cocos2d does rendering ...

  2. error eslint@5.12.0: The engine "node" is incompatible with this module.

    初始化 react项目时报错: error eslint@5.12.0: The engine "node" is incompatible with this module. E ...

  3. cocos2d-x 3.0 画图节点——Node

    ***************************************转载请注明出处:http://blog.csdn.net/lttree************************** ...

  4. Cocos2D将v1.0的tileMap游戏转换到v3.4中一例(四)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 现在打开MainScene.m文件,首先设置实例变量: @imp ...

  5. Cocos2D将v1.0的tileMap游戏转换到v3.4中一例(八)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 回到Xcode中,新建一个EndLayer类,继承于CCNode ...

  6. Cocos2D将v1.0的tileMap游戏转换到v3.4中一例(一)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请告诉我,如果觉得不错请多多支持点赞.谢谢! hopy ;) 首先说一下为什么要转换,这是为了后面的A*寻路算法做准备.由于在 ...

  7. windows平台 - 0基础学习node.js(一)

    首先得明白node.js做什么用的: 简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台. Nod ...

  8. k8s1.13.0二进制部署-node节点(四)

    Master apiserver启用TLS认证后,Node节点kubelet组件想要加入集群,必须使用CA签发的有效证书才能与apiserver通信,当Node节点很多时,签署证书是一件很繁琐的事情, ...

  9. 最新版本号cocos2d&#173;2.0&#173;x&#173;2.0.2使用新资源载入策略!不再沿用-hd、-

     前段时间cocos2dx更新了最新版本号cocos2d­2.0­x­2.0.2.也从这个版本号開始对于资源载入与管理都改变了策略. 在之前的载入方式都是通过沿用与cocos2d-iphone一样 ...

随机推荐

  1. pagination使用说明

    参考自张鑫旭 准备工作 下载jquery.min.js 下载jquery.pagination.js 下载pagination.css 开始敲代码 第一步,引入刚刚下载的三个文件 <link r ...

  2. JDOM,dom4j方式解析XML

    <?xml version="1.0" encoding="UTF-8"?> <dataSources> <!-- 定义MySQL ...

  3. vue反向代理解决跨域

    问题描述 在项目开发的时候,接口联调的时候一般都是同域名下,且不存在跨域的情况下进行接口联调,但是当我们现在使用vue-cli进行项目打包的时候,我们在本地启动服务器后,比如本地开发服务下是 http ...

  4. Python爬虫简单入门及小技巧

    刚刚申请博客,内心激动万分.于是为了扩充一下分类,随便一个随笔,也为了怕忘记新学的东西由于博主十分怠惰,所以本文并不包含安装python(以及各种模块)和python语法. 目标 前几天上B站时看到一 ...

  5. luogu P4430 小猴打架(prufer编码与Cayley定理)

    题意 n个点问有多少种有顺序的连接方法把这些点连成一棵树. (n<=106) 题解 了解有关prufer编码与Cayley定理的知识. 可知带标号的无根树有nn-2种.然后n-1条边有(n-1) ...

  6. python 比较数字大小按从大到小输出

    主要用到的python 的知识点 1:   内置函数max 2:     列表的操作 3:   while 循环 4 :  错误处理 代码如下: #!/usr/bin/python #coding=u ...

  7. Springmvc JSON交互

    先上前端javascript.ajax代码 <pre name="code" class="javascript"> function testAj ...

  8. Android平台Camera实时滤镜实现方法探讨(九)--磨皮算法探讨(一)

    上一篇开头提到了一些可用于磨皮的去噪算法.以下我们实现这些算法而且观察效果,咱不考虑实时性的问题 本文首先探讨的首先是<基于局部均方差相关信息的图像去噪及其在实时磨皮美容算法中的应用> 该 ...

  9. Maven配置Spring+SpringMVC+MyBatis(3.2.2)Pom 以及 IntelliJ IDEA 怎样打开依赖视图

    Maven配置Spring+SpringMVC+MyBatis(3.2.2)Pom 配置原则: 利用依赖,将所需的jar包加载到project中. 先依赖主要jar包 Spring + Spring ...

  10. bzoj4873: [Shoi2017]寿司餐厅(最大权闭合子图)

    4873: [Shoi2017]寿司餐厅 大难题啊啊!!! 题目:传送门 题解:一眼题是网络流,但还是不会OTZ,菜啊... %题解... 最大权闭合子图!!! 好的...开始花式建边: 1.对于每个 ...