>  기사  >  데이터 베이스  >  cocos2dx 3.X 触摸吞噬功能

cocos2dx 3.X 触摸吞噬功能

WBOY
WBOY원래의
2016-06-07 15:13:381333검색

对话框是什么,大家应该比较清楚。模态对话框就是当前对话框出现的时候不能对当前对话框以外的元素进行操作的一种对话框。 cocos里面是不自带对话框的,所以需要自己制作。一般都是新建一个层,覆盖在当前场景之上。 但是这时候常常会有一个问题,就是覆盖之

对话框是什么,大家应该比较清楚。模态对话框就是当前对话框出现的时候不能对当前对话框以外的元素进行操作的一种对话框。

cocos里面是不自带对话框的,所以需要自己制作。一般都是新建一个层,覆盖在当前场景之上。

但是这时候常常会有一个问题,就是覆盖之后,下层的点击操作依然会被相应。

这个问题我以前的做法比较naive(当然也是一种方法),就是每次把下层场景的控件都传到上层中然后 setEnable(false) 掉。但是。。。太麻烦了。


今天才知道可以在上层对话框层实现触摸吞噬,就是将所有触摸操作拦截在当前层不让其在下层有所响应。

3.X 中,因为事件处理机制的变化,需要实现一个监听器(listener)对当前层触摸操作监听并阻止其向下层传播的过程。

代码如下(一般是写在对话框层的 init 函数中)。如果在对话框层中加入,listener 需要固定在 this 上;如果在对话框下一层加入 listener 则要把对话框层的实例(也就不是 ths了)固定 listener:

	auto listener = EventListenerTouchOneByOne::create();
	listener->setSwallowTouches(true);
	listener->onTouchBegan = [](Touch* touch, Event* event)
	{
		return true;
	};
	_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this);

讲解一下。也可以看这里:
  1. setSwallowTouches 是限制本层是不是要拦截所有触摸事件,true 就是要拦截;
  2. onTouchBegan 一般是用来处理触摸事件,这里将其写空,只是让它 return 一个值。

    (1)如果返回true,则本层的Touch事件可以被触发,并阻挡向后层传递自己可以用,不让下层用);

    (2)如果返回false,本层的后续Touch事件不能被触发,并向后传递。

  3. addEventListenerWithSceneGraphPriority 是添加监听器的函数,当然也可以写作 addEventListenerWithFixedPriority。区别就是:

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

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

  4. _eventDispatcher 是cocos内置的事件分发器,无需声明直接使用就好。

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.