Cocos2d-x开发实例:单点触摸事件

下面我们通过一个实例详细了解一下层中单点触摸事件的实现过程。感受一下它的缺点和优点。该实例场景如下图所示场景中有两个方块精灵我们可以点击和移动它们。

下面我们看看HelloWorldScene.cpp具体的实现代码如下

bool HelloWorld::init()
{
    if( !Layer::init() )
    {
         returnfalse;
    }
    ......
    setTouchEnabled(true);
    //设置为单点触摸
    setTouchMode(Touch::DispatchMode::ONE_BY_ONE);                                                             

    returntrue;
}

bool HelloWorld::onTouchBegan(Touch*touch, Event* event)                                                     ①
{
    log("onTouchBegan");
    //通过tag标签获得BoxA精灵
    autoboxA = this->getChildByTag(kBoxA_Tag);                                                                           ②
    //如果BoxA精灵被点击
    if(this->isTap(boxA, touch))                                                                                                            ③
    {
         log("BoxAsprite Tap");
         boxA->runAction(ScaleBy::create(0.06,1.06));                                                                         ④
         returntrue;                                                                                                                                     ⑤
    }
    //通过tag标签获得BoxB精灵
    autoboxB = this->getChildByTag(kBoxB_Tag);                                                                   ⑥
    //如果BoxB精灵被点击
    if(this->isTap(boxB, touch))
    {
         log("BoxBsprite Tap");
         boxB->runAction(ScaleBy::create(0.06,1.06));
         returntrue;
    }                                                                                                                                                 ⑦
    returnfalse;
}

void HelloWorld::onTouchMoved(Touch*touch, Event *event)                                                     ⑧
{
    log("onTouchMoved");
    //通过tag标签获得BoxA精灵
    autoboxA = this->getChildByTag(kBoxA_Tag);
    //如果BoxA精灵被点击
    if(this->isTap(boxA, touch))
    {
         log("BoxAsprite Tap");
         //移动当前按钮精灵的坐标位置
         boxA->setPosition(boxA->getPosition()+ touch->getDelta());
         return;
    }
    //通过tag标签获得BoxB精灵
    autoboxB = this->getChildByTag(kBoxB_Tag);
    //如果BoxB精灵被点击
    if(this->isTap(boxB, touch))
    {
         log("BoxBsprite Tap");
         //移动当前按钮精灵的坐标位置
         boxB->setPosition(boxB->getPosition()+ touch->getDelta());
         return;
    }
}

void HelloWorld::onTouchEnded(Touch*touch, Event *event)                                                      ⑨
{
    log("onTouchEnded");
    //通过tag标签获得BoxA精灵
    autoboxA = this->getChildByTag(kBoxA_Tag);
    //如果BoxA精灵被点击
    if(this->isTap(boxA, touch))
    {
         log("BoxAsprite Tap");
         boxA->runAction(ScaleTo::create(0.06,1.0));
         return;
    }
    //通过tag标签获得BoxB精灵
    autoboxB = this->getChildByTag(kBoxB_Tag);
    //如果BoxB精灵被点击
    if(this->isTap(boxB, touch))
    {
         log("BoxBsprite Tap");
         boxB->runAction(ScaleTo::create(0.06,1.0));
         return;
    }
}

bool HelloWorld::isTap(Node* node,Touch* touch)                                                                    ⑩
{
    //获取触摸点相对Node位置坐标
    PointlocationInNode = node->convertToNodeSpace(touch->getLocation());                         ⑪
    Sizes = node->getContentSize();                                                                                                    ⑫
    Rectrect = Rect(0, 0, s.width, s.height);                                                                                         ⑬

    //点击范围判断检测
    if(rect.containsPoint(locationInNode))                                                                                         ⑭
    {
         returntrue;
    }
    returnfalse;
}

上述代码第①、⑧、⑨行分别定义了三个触摸事件函数函数的参数touch是在层中的触摸点event是触摸事件我们不能使用8.1.3一节的auto target = static_cast<Sprite*>(event->getCurrentTarget())语句获得要点击的精灵事实上event->getCurrentTarget()函数获得的是事件源这里的事件源是当前的层而不是精灵对象。那么我们如何判断是否点击了哪个精灵呢我的办法是每一个精灵逐一判断。所以我们在第②~⑤行代码判断精灵BoxA是否被点击在第⑥~⑦行代码判断精灵BoxB是否被点击。

代码第③行用到了isTap函数我们在第⑩行定义了该函数它是用来判断触摸点是否在精灵内这个判断主要是通过Rect的containsPoint函数判断的。函数中第⑪行代码获取触摸点相对精灵对象本地坐标。第⑫行代码是获得精灵对象的尺寸。第⑬行代码是通过精灵对象的尺寸创建Rect变量。第⑭行代码rect.containsPoint(locationInNode)是判断是否触摸点在精灵对象范围。

更多内容请关注最新Cocos图书《Cocos2d-x实战 C++卷》‍

本书交流讨论网站http://www.cocoagame.net

更多精彩视频课程请关注智捷课堂Cocos课程http://v.51work6.com

欢迎加入Cocos2d-x技术讨论群257760386

《Cocos2d-x实战 C++卷》现已上线各大商店均已开售‍

京东http://item.jd.com/11584534.html

亚马逊http://www.amazon.cn/Cocos2d-x%E5%AE%9E%E6%88%98-C-%E5%8D%B7-%E5%85%B3%E4%B8%9C%E5%8D%87/dp/B00PTYWTLU

当当http://product.dangdang.com/23606265.html

互动出版网http://product.china-pub.com/3770734

《Cocos2d-x实战 C++卷》源码及样章下载地址

源码下载地址http://51work6.com/forum.php?mod=viewthread&tid=1155&extra=page%3D1 

样章下载地址http://51work6.com/forum.php?mod=viewthread&tid=1157&extra=page%3D1

欢迎关注智捷iOS课堂微信公共平台

时间: 2024-09-23 23:05:06

Cocos2d-x开发实例:单点触摸事件的相关文章

Cocos2d-x实例:单点触摸事件

为了让大家掌握Cocos2d-x中的事件机制下面我们以触摸事件为例使用事件触发器实现单点触摸事件.该实例如图8-3所示场景中有三个方块精灵显示顺序如图8-3所示拖拽它们可以移动它们事件响应优先级是按照它们的显示顺序. 下面我们再看看具体的程序代码首先看一下HelloWorldScene.h文件它的代码如下 #ifndef __HELLOWORLD_SCENE_H__ #define __HELLOWORLD_SCENE_H__ #include "cocos2d.h" typedef

jQuery移动页面开发中的触摸事件与虚拟鼠标事件简介_jquery

触摸事件(touch)在 jQuery Mobile 中有一些触摸事件是可定制的.然而,这些事件仅当与支持触摸功能的设备进行交互的用户访问您的 jQuery Mobile 网站时才可用.当这些事件可用时,您可以触发任何自定义java script 作为对五种不同的事件的响应tap.taphold.swipe.swipeleft 和 swiperight. tap(轻击):一次快速完整的轻击后触发 taphold(轻击不放):轻击并不放(大约一秒)后触发 swipe(滑动):一秒内水平拖拽大于30

javascript移动开发中touch触摸事件详解_javascript技巧

事件对象是用来记录一些事件发生时的相关信息的对象.事件对象只有事件发生时才会产生,并且只能是事件处理函数内部访问,在所有事件处理函数运行结束后,事件对象就被销毁! W3C DOM把事件对象作为事件处理函数的第一个参数传入进去 IE将事件对象作为window对象的一个属性(相当于全局变量) originalEvent对象 在一次偶然的使用中,我发现当使用on()函数并且传入第二个选择器参数时,e.touches[0]的访问为undefined,打印e发现,它的事件对象不是原生的事件对象.经查阅发现

举例讲解iOS应用开发中hitTest触摸事件的编写方法_IOS

 hitTest:withEvet  调用过程 比如如果是当前的View A, 还有一个viewB 如果不重写 hitTest 方法,那么 系统默认是先调用viewA的hitest 方法,然后再调用viewB的htest方法. 系统的调用过程,跟下面的重写hitest的方法是一模一样的. 复制代码 代码如下: -(UIView*)hitTest:(CGPoint)point withEvent:(UIEvent *)event  {      if ([self pointInside:poin

Cocos2d-x中触摸事件

理解一个触摸事件可以从时间和空间两方面考虑. 1.触摸事件的时间方面 触摸事件的在时间方面如下图所示可以有不同的"按下"."移动"和"抬起"等阶段表示触摸是否刚刚开始.是否正在移动或处于静止状态以及何时结束也就是手指何时从屏幕抬起.此外触摸事件的不同阶段都可以有单点触摸或多点触摸是否支持多点触摸还要看设备和平台.   触摸事件有两个事件监听器EventListenerTouchOneByOne和EventListenerTouchAllAtOnc

移动端js触摸事件详解_javascript技巧

在移动开发中,一种较为容易的做法是,先在桌面上开始原型设计,然后再在打算要支持的设备上处理移动特有的部分.多点触摸正是难以在PC上进行测试的那些功能之一,因为大部分的PC都没有触摸输入.  不得不在移动设备上进行的测试有可能会拉长你的开发周期,因为你所做的每项改变都需要提交代码到服务器上,接着再加载到设备上.然后,一旦运行后,对应用也就没有太多的调试了,因为平板电脑和智能手机都很缺乏web开发者所用的工具. 这个问题的一个解决方案是在开发机器上模拟触发事件.对于单点触摸,触摸事件可以基于鼠标事件

多点触摸与单点触摸接口主要区别【转】

转自:http://blog.csdn.net/eleven_yy/article/details/7723079 上发单点触摸事件 input_report_key(input,ABS_MT_TRACKING_ID,0); input_report_key(input, BTN_TOUCH, 1); input_report_abs(input, ABS_MT_POSITION_X, ts->tc.x1); input_report_abs(input, ABS_MT_POSITION_Y,

iOS开发中使用cocos2d添加触摸事件的方法_IOS

CCLayer类是用来接收触摸输入的.不过你要首先启用这个功能才可以使用它.你通过设置isTouchEnabled为YES来让层接收触摸事件: 复制代码 代码如下: self.isTouchEnabled = YES; 此项设定最好在init方法中设置.你可以在任何时间将其设置为NO或者YES. 一旦启用isTouchEnabled属性,许多与接收触摸输入相关的方法将会开始被调用.这些事件包括:当新的触摸开始的时候,当手指在触摸屏上移动的时候,还有在用户手指离开屏幕以后.很少会发生触摸事件被取消

iOS开发之触摸事件及手势

1.iOS中的事件 在用户使用app过程中,会产生各种各样的事件,iOS中的事件可以分为3大类型: 2.响应者对象 在iOS中不是任何对象都能处理事件,只有继承了UIResponder的对象才能接收并处理事件.我们称之为"响应者对象", UIApplication.UIViewController.UIView都继承自UIResponder,因此它们都是响应者对象,都能够接收并处理事件. 2.UIResponder 继承了UIResponder就可以处理事件.UIResponder内部