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

3.0的事件分发机制中。须要也只须要通过创建一个事件监听器来实现各种触发后的逻辑,然后加入到事件分发器_eventDispatcher。全部的事件监听器由这个分发器统一管理,就可以完毕事件响应。

事件监听器有下面几种:

1、EventListenerTouch(触摸事件)

2、EventListenerKeyboard(键盘响应事件)

3、EventListenerMouse(鼠标响应事件)

4、EventListenerAcceleration(加速记录事件)

5、EventListenerCustom(自己定义事件)



_eventDispatcher的工作由三部分组成:

1、事件分发器EventDispatcher

2、事件类型EventTouch,EventKeyboard,等

3、事件监听器(上面列举的五种)

监听器实现各种触发后的逻辑,事件分发器来分发全部注冊的事件,然后调用响应的类型监听器来响应事件。



这篇来讲一下游戏中用的最多的触摸事件监听EventListenerTouch

3.0中的触摸监听变得很easy,仅仅须要注冊响应的事件监听器,给事件监听器的各个响应函数赋予响应的回调函数,最后将实现的事件监听器注冊到事件分发器_eventDispatcher中。实现各个回调函数的逻辑功能就可以。

第一步:穿件事件监听器,并注冊到时间分发器中,这一步最好在onEnter()函数中实现。

//触摸响应注冊
auto touchListener = EventListenerTouchOneByOne::create();//创建单点触摸事件监听器
touchListener->onTouchBegan = CC_CALLBACK_2(GameLayer::onTouchBegan,this);//触摸開始
touchListener->onTouchMoved = CC_CALLBACK_2(GameLayer::onTouchMoved,this);//触摸移动
touchListener->onTouchEnded = CC_CALLBACK_2(GameLayer::onTouchEnded,this);//触摸结束
_eventDispatcher->addEventListenerWithSceneGraphPriority(touchListener,this;//注冊分发器

第二步:实现上述监听器中的三个回调函数

bool GameLayer::onTouchBegan(Touch* touch, Event* event) {
//实现自己的逻辑代码
return true;
} void GameLayer::onTouchMoved(Touch* touch, Event* event) {
//实现自己的逻辑代码
} void GameLayer::onTouchEnded(Touch* touch, Event* event) {
//实现自己的逻辑代码
}

onTouchBegan()函数中返回true,则响应事件不会向下层传递,仅仅会响应本层中的Began、Moved、Ended三个函数,假设返回false,则本层兴许的Moved、Ended函数不会被触发,可是事件会向下层传递。

同一时候能够在注冊响应事件时,用

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

来设置是否向下传递触摸事件。

_eventDispatcher是Node的属性,通过它管理当前节点(场景、层、精灵等)的全部事件的分发。它本身是一个单例模式的引用。在Node的构造函数中。通过Director::getInstance()->getEventDispatcher();获取。

当一个事件监听器须要反复利用时。须要用clone()方法创建一个新的克隆。由于在使用addEventListenerWithSceneGraphPriorith或者addEventListenerWithFixedPriority方法进行注冊时。会对当前使用的事件监听器加入一个已注冊的标记,这使得它不可以被加入多次。

另外。再使用FixedPriority listeners时,加入完之后须要手动remove,SceneGraphyPriority listener和Node绑定,在Node的析构函数中会被移除。

移除一个已注冊的监听器用

_eventDispatcher->removeEventListener(listener);

也能够直接调用removeAllListeners函数。可是不建议这么做,这样做之后全部的事件监听器都不再响应。

好了,这篇主要讲了事件触摸机制,在下一篇中讲一下加速计事件。

cocos2d-x 事件分发机制 ——触摸事件监听的更多相关文章

  1. cocos2d-x游戏引擎核心(3.x)----事件分发机制之事件从(android,ios,desktop)系统传到cocos2dx的过程浅析

    (一) Android平台下: cocos2dx 版本3.2,先导入一个android工程,然后看下AndroidManifest.xml <application android:label= ...

  2. cocos2d-x 事件分发机制 ——加速计事件监听

    加速计事件监听机制 在上一篇中介绍了cocos2d-x中的触摸事件机制,这篇来介绍下游戏中也常常常使用到的加速计事件,这些都是游戏中的常常要用到的. 移动设备上一个非常重要的输入源是设备的方向.大多数 ...

  3. 浅谈Android中的事件分发机制

    View事件分发机制的本质就是就是MotionEvent事件的分发过程,即MotionEvent产生后是怎样在View之间传递及处理的. 首先介绍一下什么是MotionEvent.所谓MotionEv ...

  4. 【Unity游戏开发】用C#和Lua实现Unity中的事件分发机制EventDispatcher

    一.简介 最近马三换了一家大公司工作,公司制度规范了一些,因此平时的业余时间多了不少.但是人却懒了下来,最近这一个月都没怎么研究新技术,博客写得也是拖拖拉拉,周六周天就躺尸在家看帖子.看小说,要么就是 ...

  5. 本以为精通Android事件分发机制,没想到被面试官问懵了

    文章中出现的源码均基于8.0 前言 事件分发机制不仅仅是核心知识点更是难点,并且还是View的一大难题滑动冲突解决方法的理论基础,因此掌握好View的事件分发机制是十分重要的. 一.基本认识 1. 事 ...

  6. IOS 触摸事件分发机制详解

    欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:MelonTeam 前言 很多时候大家都不关心IOS触摸事件的分发机制的实现原理,当遇到以下几种情形的时候你很可能抓破头皮都找不到解决方案 ...

  7. 高级UI晋升之触摸事件分发机制(一)

    更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680 0. 前言 鉴于安卓分发机制较为复杂,故分为多个层次进行讲解,分别为基础篇.实践 ...

  8. Cocos2d-X研究之v3.x 事件分发机制具体解释

    事件分发机制 " src="http://www.cgzhw.com/wp-content/uploads/2014/07/inherent3.png" style=&q ...

  9. Android事件分发机制浅谈(一)

    ---恢复内容开始--- 一.是什么 我们首先要了解什么是事件分发,通俗的讲就是,当一个触摸事件发生的时候,从一个窗口到一个视图,再到一个视图,直至被消费的过程. 二.做什么 在深入学习android ...

随机推荐

  1. UVa 11552 DP Fewest Flops

    题解 #include <cstdio> #include <cstring> #include <algorithm> using namespace std; ...

  2. Mantis安装与配置

    什么是Mantis MantisBT is a free popular web-based bugtracking system (feature list). It is written in t ...

  3. Selenium WebDriver- 隐式等待

    隐式等待是只要有一个元素在设置的时间内没有找到,就会报超时 隐式等待是一个全局的设置,只要放在找东西语句的前面,它后面的找东西的语句都会默认等待设置的时间(这里是10秒),这是死等,除非立刻找到了,5 ...

  4. python - 接口自动化测试 - ReadExcel - 读取测试数据封装

    # -*- coding:utf-8 -*- ''' @project: ApiAutoTest @author: Jimmy @file: read_excel.py @ide: PyCharm C ...

  5. day04_03 题目判断三个数字中的最大值

    num1 = input("Num1:") num2 = input("Num2:") num3 = input("Num3:") 输出三个 ...

  6. 异常详细信息: System.Data.SqlClient.SqlException: 用户 'NT AUTHORITY\IUSR' 登录失败解决办法

    最近在做.net项目,因为本人以前做java较多,所以对.net不熟悉,在项目完成后部署到IIS服务器上出现诸多问题,以上其中之一,若有时间,在更新其他问题的解决办法! 异常详细信息: System. ...

  7. 【Luogu】P2536病毒检测(Trie上DP)

    题目链接 这道题我写了个01DP,f[i][j]表示跑到Trie上第i个节点,匹配到字符串第j位行不行 然后重点在*号无限匹配怎么处理 经过一番脑洞我们可以发现*号无限匹配可以拆成两种情况: 1:匹配 ...

  8. ACM程序设计选修课——1018: Common Subsequence(DP)

    问题 L: Common Subsequence 时间限制: 1 Sec  内存限制: 32 MB 提交: 70  解决: 40 [提交][状态][讨论版] 题目描述 A subsequence of ...

  9. [OJ#63]树句节够提

    [OJ#63]树句节够提 试题描述 给定一棵节点数为 N 的有根树,其中 1 号点是根节点,除此之外第 i 个节点的父亲为 fi.每个节点有一个权值 Ai,所有边权均为 1. 给定 Q 个询问,每个询 ...

  10. [NOIP2009] $Hankson$ 的趣味题 (数论,gcd)

    题目链接 Solution 此题,用到的结论都是比较浅显的,但是,我竟然没想到反过来枚举... 只有50分... 被自己蠢哭... 结论比较浅显: 1.对于两个正整数\(a\),\(b\),设 \(g ...