利用cocos2dx 3.2开发消灭星星(五)update与触摸事件

原创 2014年09月10日 20:48:48

上一节我们一直在讲星星有两个位置,当前位置与目标位置。究竟是什么,有什么用。这一节为你解答。

所谓的当前位置,就是星星当前所处的位置,是可以改变的。

所谓的目标位置,就是星星要到达的位置,如果星星的当前位置不等于目标星星,星星的当前位置会不断地改变,直到移动到目标位置。

但是说起来简单,设置了这两个位置,到底怎么实现星星从当前位置移动到目标位置?


这里我们重新看之前被我们忽略的GameLayer中的update函数

void GameLayer::update(float delta){
	if(matrix){
		matrix->updateStar(delta);
	}
}

看到没有,GameLayer中的update其实就是调用内置星星矩阵matrix的updateStar方法。

之前我们介绍StarMatrix的时候可能还没有加入updateStar这个函数,没关系,在StarMatrix类中加入就好

void StarMatrix::updateStar(float delta){
	
	for(int i = 0;i < ROW_NUM;i++){
		for(int j = 0;j< COL_NUM;j++){
			if(stars[i][j]!=nullptr){
				stars[i][j]->updatePosition();
			}
		}
	}	
}


同样的StarMatrix的update方法也是调用比他更小的Star的updatePosition方法(其实就是在Layer层开启update,一层一层向下传递)

void Star::updatePosition(){
	if(desPosition.y != getPositionY()){
		setPositionY(getPositionY() - MOVE_SPEED);
		if(getPositionY() < desPosition.y){
			setPositionY(desPosition.y);
		}
	}
	if(desPosition.x != getPositionX()){
		setPositionX(getPositionX() - MOVE_SPEED);
		if(getPositionX() < desPosition.x){
			setPositionX(desPosition.x);
		}
	}
}

到这里还不清晰吗?updatePosition就会判断当前位置跟目标位置desPosition是否一样,从而逐渐改变Star的position,使之逐渐移动到desPosition

以后我们在对Star赋值的时候,只要Star的当前位置与desPosition位置不一样,Star就会自动向desPosition移动。


这里的update是从GameLayer一层一层地往下传到Star。


触摸事件也同样。

在GameLayer中的init函数中开启触摸事件。

EventListenerTouchOneByOne* listener = EventListenerTouchOneByOne::create();
	listener->onTouchBegan = CC_CALLBACK_2(GameLayer::onTouchBegan,this);

onTouchBegan函数:

bool GameLayer::onTouchBegan(Touch* touch,Event* event){
	Point p = touch->getLocationInView();
	p = Director::getInstance()->convertToGL(p);
	CCLOG("x=%f y=%f",p.x,p.y);
	if(matrix){
		matrix->onTouch(p);
	}
	return true;
}
看到没,这里把得到的触摸点传给了StarMatrix


但是StarMatrix可不会将触摸点又传给单个星星Star,应为单个星星是孤立的,传给它没用。。。

总之,我们的StarMatrix已经接受到触摸点了,具体怎么根据触摸点对自己本身的Star*二维数组进行操作,以后再说吧。



相关文章推荐

【Cocos2dx-3.x】通信协议之WebSocket通信协议篇

好记性不如烂笔头 前言 WebSockets协议的优势在于: 1. Header : 互相沟通的Header是很小的-大概只有 2 Bytes 2. Server Push : 服...
  • sszyc8
  • sszyc8
  • 2014年10月10日 17:05
  • 2658

利用cocos2dx 3.2开发消灭星星(一)基本介绍

最近在大哥那边接到一个任务,用cocos2dx开发一款消灭星星。开始的时候想上网找个demo,但找到的是cocos2d-js版的。唯一找到一个也是基于cocos2dx2.2开发出来的,与现在的3.2版...

利用cocos2dx 3.2开发消灭星星(四)游戏主场景

第二节说到在菜单场景MenuScene中加入一个菜单并且加入一个开始按钮切换到GameScene,下面我们来讲一下游戏的主界面GameScene和GameLayer 一、主场景GameScene ...

利用cocos2dx 3.2开发消灭星星(九)为游戏添加一些特效

其实整个消灭星星开发也差不多了,为了使游戏好看些,不如为游戏添加一些...

利用cocos2dx 3.2开发消灭星星(八)游戏的结束判断与数据控制

如果你看完之前的,那么你基本已经拥有一个消灭星星

cocos2dx 3.2 解决触摸事件中两个按钮同时响应的问题

上篇触摸机制讲解中提到过存在两个按钮同时响应的问题。
  • wly_lly
  • wly_lly
  • 2014年12月29日 19:26
  • 1561

cocos2dx 精灵触摸事件的实现

  • 2014年05月16日 19:22
  • 1KB
  • 下载

利用cocos2dx 3.2开发消灭星星(七)关于星星的算法

在前面,我们已经在GameLayer中利用随机数初始化了一个StarMatrix(星星矩阵:即所有的星星)...

利用cocos2dx 3.2开发消灭星星(六)如何在cocos2dx中显示中文

由于编码的不同,在cocos2dx中的Label控件中如果放入

quick-cocos2dx lua语言讲解 (动作,定时器,触摸事件,工程的类的讲解)

quick-cocos2dx lua语言讲解 (动作,定时器,触摸事件,工程的类的讲解)
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:利用cocos2dx 3.2开发消灭星星(五)update与触摸事件
举报原因:
原因补充:

(最多只允许输入30个字)