cocos2d-x 事件分发机制 ——触摸事件监听
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 事件分发机制 ——触摸事件监听的更多相关文章
- cocos2d-x游戏引擎核心(3.x)----事件分发机制之事件从(android,ios,desktop)系统传到cocos2dx的过程浅析
(一) Android平台下: cocos2dx 版本3.2,先导入一个android工程,然后看下AndroidManifest.xml <application android:label= ...
- cocos2d-x 事件分发机制 ——加速计事件监听
加速计事件监听机制 在上一篇中介绍了cocos2d-x中的触摸事件机制,这篇来介绍下游戏中也常常常使用到的加速计事件,这些都是游戏中的常常要用到的. 移动设备上一个非常重要的输入源是设备的方向.大多数 ...
- 浅谈Android中的事件分发机制
View事件分发机制的本质就是就是MotionEvent事件的分发过程,即MotionEvent产生后是怎样在View之间传递及处理的. 首先介绍一下什么是MotionEvent.所谓MotionEv ...
- 【Unity游戏开发】用C#和Lua实现Unity中的事件分发机制EventDispatcher
一.简介 最近马三换了一家大公司工作,公司制度规范了一些,因此平时的业余时间多了不少.但是人却懒了下来,最近这一个月都没怎么研究新技术,博客写得也是拖拖拉拉,周六周天就躺尸在家看帖子.看小说,要么就是 ...
- 本以为精通Android事件分发机制,没想到被面试官问懵了
文章中出现的源码均基于8.0 前言 事件分发机制不仅仅是核心知识点更是难点,并且还是View的一大难题滑动冲突解决方法的理论基础,因此掌握好View的事件分发机制是十分重要的. 一.基本认识 1. 事 ...
- IOS 触摸事件分发机制详解
欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:MelonTeam 前言 很多时候大家都不关心IOS触摸事件的分发机制的实现原理,当遇到以下几种情形的时候你很可能抓破头皮都找不到解决方案 ...
- 高级UI晋升之触摸事件分发机制(一)
更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680 0. 前言 鉴于安卓分发机制较为复杂,故分为多个层次进行讲解,分别为基础篇.实践 ...
- Cocos2d-X研究之v3.x 事件分发机制具体解释
事件分发机制 " src="http://www.cgzhw.com/wp-content/uploads/2014/07/inherent3.png" style=&q ...
- Android事件分发机制浅谈(一)
---恢复内容开始--- 一.是什么 我们首先要了解什么是事件分发,通俗的讲就是,当一个触摸事件发生的时候,从一个窗口到一个视图,再到一个视图,直至被消费的过程. 二.做什么 在深入学习android ...
随机推荐
- UVa 11552 DP Fewest Flops
题解 #include <cstdio> #include <cstring> #include <algorithm> using namespace std; ...
- Mantis安装与配置
什么是Mantis MantisBT is a free popular web-based bugtracking system (feature list). It is written in t ...
- Selenium WebDriver- 隐式等待
隐式等待是只要有一个元素在设置的时间内没有找到,就会报超时 隐式等待是一个全局的设置,只要放在找东西语句的前面,它后面的找东西的语句都会默认等待设置的时间(这里是10秒),这是死等,除非立刻找到了,5 ...
- python - 接口自动化测试 - ReadExcel - 读取测试数据封装
# -*- coding:utf-8 -*- ''' @project: ApiAutoTest @author: Jimmy @file: read_excel.py @ide: PyCharm C ...
- day04_03 题目判断三个数字中的最大值
num1 = input("Num1:") num2 = input("Num2:") num3 = input("Num3:") 输出三个 ...
- 异常详细信息: System.Data.SqlClient.SqlException: 用户 'NT AUTHORITY\IUSR' 登录失败解决办法
最近在做.net项目,因为本人以前做java较多,所以对.net不熟悉,在项目完成后部署到IIS服务器上出现诸多问题,以上其中之一,若有时间,在更新其他问题的解决办法! 异常详细信息: System. ...
- 【Luogu】P2536病毒检测(Trie上DP)
题目链接 这道题我写了个01DP,f[i][j]表示跑到Trie上第i个节点,匹配到字符串第j位行不行 然后重点在*号无限匹配怎么处理 经过一番脑洞我们可以发现*号无限匹配可以拆成两种情况: 1:匹配 ...
- ACM程序设计选修课——1018: Common Subsequence(DP)
问题 L: Common Subsequence 时间限制: 1 Sec 内存限制: 32 MB 提交: 70 解决: 40 [提交][状态][讨论版] 题目描述 A subsequence of ...
- [OJ#63]树句节够提
[OJ#63]树句节够提 试题描述 给定一棵节点数为 N 的有根树,其中 1 号点是根节点,除此之外第 i 个节点的父亲为 fi.每个节点有一个权值 Ai,所有边权均为 1. 给定 Q 个询问,每个询 ...
- [NOIP2009] $Hankson$ 的趣味题 (数论,gcd)
题目链接 Solution 此题,用到的结论都是比较浅显的,但是,我竟然没想到反过来枚举... 只有50分... 被自己蠢哭... 结论比较浅显: 1.对于两个正整数\(a\),\(b\),设 \(g ...