cocos2d-x 3.0触摸机制的用法

转载 2015年07月08日 18:32:17

原作者:草莓vc


在cocos2dx 3.0版本中,废弃了以往2.x版本的写法,我们先来看一下Layer.h中的一段代码:

[cpp]view plaincopy

//单点触摸

virtualbool onTouchBegan(Touch *touch, Event *unused_event);   

virtualvoid onTouchMoved(Touch *touch, Event *unused_event);   

virtualvoid onTouchEnded(Touch *touch, Event *unused_event);   

virtualvoid onTouchCancelled(Touch *touch, Event *unused_event);  

//多点触摸

virtualvoid onTouchesBegan(const std::vector<Touch*>& touches, Event *unused_event);  

virtualvoid onTouchesMoved(const std::vector<Touch*>& touches, Event *unused_event);  

virtualvoid onTouchesEnded(const std::vector<Touch*>& touches, Event *unused_event);  

virtualvoid onTouchesCancelled(const std::vector<Touch*>&touches, Event *unused_event); 

____________________________________________________________________________________

单点触摸:(即只有注册的Layer才能接收触摸事件)

 onTouchBegan:     如果返回true:本层的后续Touch事件可以被触发,并阻挡向后层传递

                                 如果返回false,本层的后续Touch事件不能被触发,并向后传递,也就是不会调用onTouchMoved

简单点来说,如果

1.Layer 只有一层的情况:

virtual bool onTouchBegan(CCTouch *pTouch, CCEvent *pEvent);

a.返回false,则ccTouchMoved(),ccTouchEnded()不会再接收到消息

b.返回true,则ccTouchMoved(),ccTouchEnded()可以接收到消息

2.Layer 有多层的情况:

virtual bool onTouchBegan(CCTouch *pTouch, CCEvent *pEvent);

a.返回false,则本层的onTouchMoved(),onTouchEnded()不会再接收到消息,但是本层之下的其它层会接收到消息

b.返回true,则本层的onTouchMoved(),onTouchEnded()可以接收到消息,但是本层之下的其它层不能再接收到消息

单点触摸简单用法:

在Layer中添加如下代码,重写onTouchxxx函数:

[cpp]view plaincopy

       auto dispatcher = Director::getInstance()->getEventDispatcher();  

auto listener = EventListenerTouchOneByOne::create();  

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

listener->onTouchMoved = CC_CALLBACK_2(GameLayer::onTouchMoved,this);  

listener->onTouchEnded = CC_CALLBACK_2(GameLayer::onTouchEnded,this);  

listener->setSwallowTouches(true);//不向下传递触摸

dispatcher->addEventListenerWithSceneGraphPriority(listener,this);  

____________________________________________________________________________________

listener->setSwallowTouches(true),不向下触摸,简单点来说,比如有两个sprite ,A 和 B,A在上B在下(位置重叠),触摸A的时候,B不会受到影响

 listener->setSwallowTouches(false)反之,向下传递触摸,触摸A也等于触摸了B

多点触摸点单用法(多个Layer获取屏幕事件):

[cpp]view plaincopy

       auto dispatcher = Director::getInstance()->getEventDispatcher();  

auto listener1 = EventListenerTouchAllAtOnce::create();  

listener1->onTouchesBegan = CC_CALLBACK_2(GameLayer::onTouchesBegan,this);  

listener1->onTouchesMoved = CC_CALLBACK_2(GameLayer::onTouchesMoved,this);  

listener1->onTouchesEnded = CC_CALLBACK_2(GameLayer::onTouchesEnded,this);  

dispatcher->addEventListenerWithSceneGraphPriority(listener1,this);  

______________________________________________________________________________________

或者setTouchEnabled(true),然后重写layer的onTouchsxxx函数

关于eventDispatcher:

获取方法:

[cpp] view plaincopy在CODE上查看代码片派生到我的代码片 

auto dispatcher = Director::getInstance()->getEventDispatcher();  

事件监听器包含以下几种:

触摸事件 (EventListenerTouch)

键盘响应事件 (EventListenerKeyboard)

加速记录事件 (EventListenerAcceleration)

鼠标响应事件 (EventListenerMouse)

自定义事件 (EventListenerCustom)

以上事件监听器统一由 _eventDispatcher 来进行管理。

优先权:

1.优先级越低,越先响应事件

2.如果优先级相同,则上层的(z轴)先接收触摸事件

有两种方式将 事件监听器 listener1 添加到 事件调度器_eventDispatcher 中:

[cpp] view plaincopy在CODE上查看代码片派生到我的代码片 

void EventDispatcher::addEventListenerWithSceneGraphPriority(EventListener* listener, Node* node)  

    void EventDispatcher::addEventListenerWithFixedPriority(EventListener* listener, int fixedPriority)  

代码展开一下:

[cpp] view plaincopy在CODE上查看代码片派生到我的代码片 

void EventDispatcher::addEventListenerWithSceneGraphPriority(EventListener* listener, Node* node)  

{  

    CCASSERT(listener && node, "Invalid parameters.");  

    CCASSERT(!listener->isRegistered(), "The listener has been registered.");  

    if (!listener->checkAvailable())  

        return;  

    listener->setSceneGraphPriority(node);  

    listener->setFixedPriority(0);  

    listener->setRegistered(true);  

    addEventListener(listener);  

}  

[cpp] view plaincopy在CODE上查看代码片派生到我的代码片 

void EventDispatcher::addEventListenerWithFixedPriority(EventListener* listener, int fixedPriority)  

{  

    CCASSERT(listener, "Invalid parameters.");  

    CCASSERT(!listener->isRegistered(), "The listener has been registered.");  

    CCASSERT(fixedPriority != 0, "0 priority is forbidden for fixed priority since it's used for scene graph based priority.");  

    if (!listener->checkAvailable())  

        return;  

    listener->setSceneGraphPriority(nullptr);  

    listener->setFixedPriority(fixedPriority);  

    listener->setRegistered(true);  

    listener->setPaused(false);  

    addEventListener(listener);  

}  

(1)addEventListenerWithSceneGraphPriority 的事件监听器优先级是0,而且在 addEventListenerWithFixedPriority 中的事件监听器的优先级不可以设置为 0,因为这个是保留给 SceneGraphPriority 使用的。

(2)另外,有一点非常重要,FixedPriority listener添加完之后需要手动remove,而SceneGraphPriority listener是跟node绑定的,在node的析构函数中会被移除。

移除方法:

[cpp] view plaincopy在CODE上查看代码片派生到我的代码片 

dispatcher->removeEventListener(listener);  

其实还可以这么用:

    //1加入用户触摸事件侦听

    auto listener=EventListenerTouchOneByOne::create();

    listener->setSwallowTouches(true);

    listener->onTouchBegan=[&](Touch * t,Event * e){

        //改变贪食蛇移动的方向

        int col=t->getLocation().x/32;

        int row=t->getLocation().y/32;

        int spHeadCol=spHead->getPositionX()/32;

        int spHeadRow=spHead->getPositionY()/32;

        if(abs(spHeadCol-col)>abs(spHeadRow-row))

        {

           if(spHeadCol<col)

            {

            spHead->m_dir=ENUM_DIR::DIR_RIGHT;

            }else

            {

                spHead->m_dir=ENUM_DIR::DIR_LEFT;

            }

        }

        else

            {if(spHeadRow<row)

                {

                spHead->m_dir=ENUM_DIR::DIR_UP;

                }else

                    {

                    spHead->m_dir=ENUM_DIR::DIR_DOWN;

                    }     

        }

        return true;

    }; //这条语句像不像Java中的匿名接口对象,像不像Objective-C中Block ,他有个很华丽的名字 lambda,读音为:腊母达,相信未来你会喜欢上这妹子的

//3注册这个侦听到消息分发器中   

_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this);

 

相关文章推荐

cocos2d-x 3.0 事件分发机制 —触摸事件监听

cocos2d-x 3.0 出来已经好久了,也已经用3.0写了几个小游戏,感觉3.0的事件触发机制太赞了,随这里总结一下,也算是对知识的一种回忆和加深理解。 3.0的事件分发机制中,需要也仅仅需要通...

Cocos2d-x 3.0 屏幕触摸及消息分发机制

Cocos2d-x 3.0 屏幕触摸 消息分发机制 新手入门

Cocos2d-x 3.0 屏幕触摸及消息分发机制

***************************************转载请注明出处:http://blog.csdn.net/lttree**************************...
  • Cui860
  • Cui860
  • 2014年09月03日 17:58
  • 332

Cocos2d-x 3.0 新特性体验-触摸事件处理机制

在cocos2d-x 2.x版本中,相信大家都抱怨过其中的触摸机制;在3.0版本中,采用了全新的触摸事件处理机制。 在官方的文档中:点击打开链接  这篇文章有对新的事件分发机制的介绍。 下...

Cocos2d-x 3.0 触摸事件处理机制

原文:http://blog.csdn.net/crayondeng/article/details/18795451 在cocos2d-x 2.x版本中,相信大家都抱怨过其中的触摸机制;在3....

Cocos2d-x 3.0 新特性体验(3)触摸事件处理机制

在cocos2d-x 2.x版本中,相信大家都抱怨过其中的触摸机制;在3.0版本中,采用了全新的触摸事件处理机制。 在官方的文档中:点击打开链接  这篇文章有对新的事件分发机制的介绍。 下面,我将通过...

【amazing cocos2d-x 3.0之五】新的触摸机制

我们将从源码级来分析cocos2d-x 3.0新的触摸机制。 运行引擎本身的TestCpp之后,我们可以看到Touchable Sprite Test,如下图,我们将从这里开始分析。 这个例子实现...

【amazing cocos2d-x 3.0之四】新触摸机制的前奏——Lambda

在介绍3.0新的触摸机制之前,我们有必要先介绍一下3.0新引进的C++ 11的Lambda表达式。 1. Lambda表达式 首先,什么是Lambda表达式呢? Lambda表达式是一个匿名函数...

Cocos2d-x 3.0---触摸机制

原文:http://blog.csdn.net/sdhjob/article/details/27524477

【amazing cocos2d-x 3.0之六】事件分发机制

1. 介绍 (1)在使用时,首先创建一个事件监听器,事件监听器包含以下几种: 触摸事件(EventListenerTouch) 键盘响应事件(EventListenerKeyboard)...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:cocos2d-x 3.0触摸机制的用法
举报原因:
原因补充:

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