cocos 触摸机制

2024-08-29 07:18
文章标签 机制 触摸 cocos

本文主要是介绍cocos 触摸机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

假设要实现拖动一个精灵移动,那我们的步骤是:

1、 创建一个精灵sprite

2、一个触摸事件 listener ,设置listener的onTouchBegan,onTouchMoved,onTouchEnded;

3、将sprite 和 listener关联起来。

 

实现如下:

1、 创建精灵:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. Point origin = Director::getInstance()->getVisibleOrigin();  
  2. Size size = Director::getInstance()->getVisibleSize();  
  3.   
  4. auto sprite = Sprite::create("Images/CyanSquare.png");  
  5. sprite->setPosition(origin+Point(size.width/2, size.height/2) + Point(-80, 80));  
  6. addChild(sprite, 1);  

2、 创建 listener

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. auto listener1 = EventListenerTouchOneByOne::create();//创建一个触摸监听  
  2. listener1->setSwallowTouches(true);//设置是否想下传递触摸  

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. //3.0 后可以直接在touchBegan后添加它的实现代码,而不用特意去写一个touchBegan的函数  
  2. listener1->onTouchBegan = [](Touch* touch, Event* event){  
  3. auto target = static_cast<Sprite*>(event->getCurrentTarget());//获取的当前触摸的目标  
  4.       
  5. Point locationInNode = target->convertToNodeSpace(touch->getLocation());  
  6. Size s = target->getContentSize();  
  7. Rect rect = Rect(0, 0, s.width, s.height);  
  8.       
  9. if (rect.containsPoint(locationInNode))//判断触摸点是否在目标的范围内  
  10.       return true;  
  11. else  
  12.       return false;  
  13. };  
  14.   
  15.  //拖动精灵移动  
  16. listener1->onTouchMoved = [](Touch* touch, Event* event){  
  17.     auto target = static_cast<Sprite*>(event->getCurrentTarget());  
  18.     target->setPosition(target->getPosition() + touch->getDelta());  
  19. };  
  20.   
  21. listener1->onTouchEnded = [=](Touch* touch, Event* event){  
  22. };  
  23. //将触摸监听添加到eventDispacher中去  
  24. _eventDispatcher->addEventListenerWithSceneGraphPriority(listener1 ,sprite);  
[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. }  

以上就是移动一个精灵的实现过程,这里特意交代一些细节:

1)触摸监听listener的创建方式有两种,一种是:EventListenerTouchOneByOne,另一种是:EventListenerTouchAllAtOnce,顾名思义,EventListenerTouchOneByOne的意思单点触摸,EventListenerTouchAllAtOnce,是多点触摸,而不需要再用设置Delegate的方式来做了。3.0触摸机制还有个不同的地方,只要是放在最上面的那个精灵,那它的触摸优先级就最高。我们用的按钮Menu 就是用这种方式设置触摸优先级的。而

2)将listener1添加到事件调度中,这里用的是:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. _eventDispatcher->addEventListenerWithSceneGraphPriority(listener1 sprite);  

我们进入addEventListenerWithSceneGraphPriority的定义中看一下,有下面这一行代码:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. listener->setFixedPriority(0);  

它将精灵的触摸优先级设置成0,从这里我们可以引申出两个问题,一个就是当我们要给精灵设置触摸优先级时,

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. listener->setFixedPriority(0);  
,因为0已经被“官府”征用了,另一个问题就是:如果自己想设置精灵的触摸优先级,那应该怎么做呢?下面是提供的另外一种添加listener的方法:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. _eventDispatcher->addEventListenerWithFixedPriority(listener1 ,fixedPriority);  

在第二个参数里设置触摸优先级,这样就可以了。

3)如果你有多个精灵sprite,且这些精灵都想实现拖动的功能,那么这些精灵都可以使用listener1这一个触摸监听,例如我们有三个精灵,sprite,sprite2,sprite3,他们调用listener1的方式:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1.  _eventDispatcher->addEventListenerWithSceneGraphPriority(listener1, sprite1);  
  2.  _eventDispatcher->addEventListenerWithSceneGraphPriority(listener1->clone(), sprite2);  
  3. _eventDispatcher->addEventListenerWithSceneGraphPriority(listener1->clone(), sprite3);  

其中sprite2和sprite3都是克隆了listener1的,进入clone()的定义,我们看到以下代码:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. EventListenerTouchOneByOne* EventListenerTouchOneByOne::clone()  
  2. {  
  3.     auto ret = new EventListenerTouchOneByOne();  
  4.     if (ret && ret->init())  
  5.     {  
  6.         ret->autorelease();  
  7.           
  8.         ret->onTouchBegan = onTouchBegan;  
  9.         ret->onTouchMoved = onTouchMoved;  
  10.         ret->onTouchEnded = onTouchEnded;  
  11.         ret->onTouchCancelled = onTouchCancelled;  
  12.           
  13.         ret->_claimedTouches = _claimedTouches;  
  14.         ret->_needSwallow = _needSwallow;  
  15.     }  
  16.     else  
  17.     {  
  18.         CC_SAFE_DELETE(ret);  
  19.     }  
  20.     return ret;  
  21. }  

以上代码主要的目的也就是实现克隆touchbegan,touchmoved,touchended。

3、删除触摸监听

如果想移除sprite的触摸移动,可以这么做:

[cpp]  view plain copy 在CODE上查看代码片 派生到我的代码片
  1. _eventDispatcher->removeEventListeners(EventListener::Type::TOUCH_ONE_BY_ONE);  

这样就OK了。

这篇关于cocos 触摸机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1117205

相关文章

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

C# async await 异步编程实现机制详解

《C#asyncawait异步编程实现机制详解》async/await是C#5.0引入的语法糖,它基于**状态机(StateMachine)**模式实现,将异步方法转换为编译器生成的状态机类,本... 目录一、async/await 异步编程实现机制1.1 核心概念1.2 编译器转换过程1.3 关键组件解析

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Go语言并发之通知退出机制的实现

《Go语言并发之通知退出机制的实现》本文主要介绍了Go语言并发之通知退出机制的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、通知退出机制1.1 进程/main函数退出1.2 通过channel退出1.3 通过cont

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

Java中的xxl-job调度器线程池工作机制

《Java中的xxl-job调度器线程池工作机制》xxl-job通过快慢线程池分离短时与长时任务,动态降级超时任务至慢池,结合异步触发和资源隔离机制,提升高频调度的性能与稳定性,支撑高并发场景下的可靠... 目录⚙️ 一、调度器线程池的核心设计 二、线程池的工作流程 三、线程池配置参数与优化 四、总结:线程

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class