5.触摸touch,单点触摸,多点触摸,触摸优先和触摸事件的吞噬



1
触摸

Coco2dx默认仅仅有CCLayer及其派生类才有触摸的功能。

2
单点触摸

打开触摸开关和触摸方式

setTouchEnabled(true);

setTouchMode(kCCTouchesOneByOne);

Cocos2dx
对触摸分三布来处理。分是是点触。移动。离开。

或是中间被打断。

其功能皆有对应的virtual
函数进行override
的。


virtual bool ccTouchBegan(CCTouch *pTouch,CCEvent *pEvent);


virtual void ccTouchMoved(CCTouch *pTouch,CCEvent *pEvent);


virtual void ccTouchEnded(CCTouch *pTouch,CCEVENT *pEvent);


virtual void ccTouchCancelled(CCTouch *pTouch,CCEvent *pEvent);

获取点击的坐标点


CCPoint pt = pTouch->getLocation();

CCLog(“x=%f y=%f”,pt.x,pt.y);

理解getDelta();


ccTouchBegan

start x = 67.309761 y = 180.989975

ccTouchMoved

delta x = 1.013191, y = 0.000000

ccTouchMoved

delta x = 5.977837, y = 0.000000

ccTouchMoved

delta x = 3.985229, y = 0.000000

ccTouchMoved

delta x = 1.013184, y = 0.000000

ccTouchMoved

delta x = 1.992615, y = 0.000000

ccTouchMoved

...................................

...................................

delta x = 1.013184, y = 0.000000

ccTouchMoved

delta x = 0.979431, y = 0.000000

ccTouchMoved

delta x = 1.992615, y = 0.000000

ccTouchMoved

delta x = 3.005798, y = 0.000000

ccTouchMoved

delta x = 3.005798, y = 0.000000

ccTouchMoved

delta x = 2.972015, y = 0.000000

ccTouchMoved

delta x = 1.013214, y = 0.000000

ccTouchMoved

delta x = 3.005798, y = 0.000000

ccTouchMoved

delta x = 0.979431, y = 0.000000

ccTouchEnded

3
多点触摸

打开触摸开关,系统默觉得单点触摸。


setTouchEnabled(true);

cocos2dx对触摸分三部来处理。各自是点触,移动。离开。或是中间被打断。

其功能皆有对应的virtual函数进行override的。


virtual bool ccTouchesBegan(CCSet *pTouches, CCEvent *pEvent);

virtual void ccTouchesMoved(CCSet *pTouches, CCEvent *pEvent);

virtual void ccTouchesEnded(CCSet *pTouches, CCEvent *pEvent);

virtual void ccTouchesCancelled(CCSet *pTouches, CCEvent *pEvent);

获取点击的坐标点。

4
案例(打飞机)


Touch.h


#ifndef
__TOUCH_H__

#define
__TOUCH_H__

#include
"cocos2d.h"

USING_NS_CC;

class
Touch :public
CCLayerColor

{

public:

static
CCScene *
scene();

CREATE_FUNC(Touch);

bool
init();

enum
MyEnum

{

BN747

};

bool
ccTouchBegan(CCTouch
*pTouch,
CCEvent *pEvent);

void
ccTouchMoved(CCTouch
*pTouch,
CCEvent *pEvent);

void
ccTouchEnded(CCTouch
*pTouch,
CCEvent *pEvent);

void
ccTouchCancelled(CCTouch
*pTouch,
CCEvent *pEvent);

};

#endif


Touch.cpp


#include
"Touch.h"

#include
"AppMacros.h"

CCScene *Touch::scene()

{

CCScene *
scene =
CCScene::create();

Touch *
layer =
Touch::create();

scene->addChild(layer);

return
scene;

}

bool
Touch::init()

{

CCLayerColor::initWithColor(ccc4(255,
255, 255, 255));

setTouchEnabled(true);

setTouchMode(kCCTouchesOneByOne);

CCSprite *
plane =
CCSprite::create("hero1.png");

plane->setPosition(ccp(100,
100));

addChild(plane);

plane->setTag(BN747);

return
true;

}

bool
Touch::ccTouchBegan(CCTouch
*pTouch,
CCEvent *pEvent)

{

CCSprite *
plane = (CCSprite
*)getChildByTag(BN747);

CCPoint
pt =
pTouch->getLocation();

if (plane->boundingBox().containsPoint(pt))

{

CCLOG("touched");

return
true;

}

//决定消息是否往下传递

return
false;

}

void
Touch::ccTouchMoved(CCTouch
*pTouch,
CCEvent *pEvent)

{

CCSprite *
plane = (CCSprite
*)getChildByTag(BN747);

CCPoint
pt =
plane->getPosition()
+ pTouch->getDelta();

if (pt.x
> plane->getContentSize().width
/ 2

&& pt.x
< winSize.width
- plane->getContentSize().width
/ 2

&& pt.y
> plane->getContentSize().height
/ 2

&& pt.y
< winSize.height
- plane->getContentSize().height
/ 2)

{

plane->setPosition(pt);

}

CCLog("ccTouchMoved
x = %g y = %g",
pt.x,
pt.y);

}

void
Touch::ccTouchEnded(CCTouch
*pTouch,
CCEvent *pEvent)

{

CCLog("ccTouchEnded");

}

void
Touch::ccTouchCancelled(CCTouch
*pTouch,
CCEvent *pEvent)

{

CCLog("ccTouchCancelled");

}


执行结果:

时间: 2024-08-10 21:11:23

5.触摸touch,单点触摸,多点触摸,触摸优先和触摸事件的吞噬的相关文章

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

转自: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,

【unity3D】单点和多点触控

[狗刨学习网] 总结: Input.touchCount获取当前的触摸点数目,若为1则是单点触控,大于1则是多点触控 点击事件用:Input.GetTouch(num).phase == TouchPhase.Began这样的格式 代码: using UnityEngine; using System.Collections; public class click2 : MonoBehaviour { //设置点击时显示的图片 public Texture2D img; void Start (

《从零开始学Swift》学习笔记(Day 68)——Cocoa Touch设计模式及应用之响应者链与触摸事件

原创文章,欢迎转载.转载请注明:关东升的博客 应用与用户进行交互,依赖于各种各样的事件.事件响应者对象是可以响应事件并对其进行处理的对象,响应者链是由一系列链接在一起的响应者组成的.响应者链在事件处理中是非常重要的,响应者链可以把用户事件路由给正确的对象. 响应者对象与响应链 UIResponder是所有响应者对象的基类,它不仅为事件处理,而且也为常见的响应者行为定义编程接口.UIApplication.UIView(及其子类,包括UIWindow)和UIViewController(及其子类)

android 触摸touch事件的派送和传递

1.touch事件从Activity开始向下逐层派发 一直派发到焦点控件进行处理 2.如果控件的事件处理方法返回true 则,该控件消费且持续关注此事件 否则,该事件向该控件的上一层容器传递 3.控件的touch监听器的onTouch方法 先于 控件本身的onTouchEvent执行 Touch事件派发和处理的方法 dispatchTouchEvent onInterceptTouchEvent(只有ViewGroup有该拦截方法) onTouchListener.onTouch onTouch

手机触摸touch事件

1.Touch事件简介 pc上的web页面鼠 标会产生onmousedown.onmouseup.onmouseout.onmouseover.onmousemove的事件,但是在移动终端如 iphone.ipod Touch.ipad上的web页面触屏时会产生ontouchstart.ontouchmove.ontouchend.ontouchcancel 事件,分别对应了触屏开始.拖拽及完成触屏事件和取消. 当按下手指时,触发ontouchstart: 当移动手指时,触发ontouchmov

485总线单点对多点问题

485总线单点对单点使用时没有多大问题,可单点对多点后问题就非常多了,485的主机是有120欧电阻的,然后有5个从设备,从设备有的有120欧电阻有的没有,然后就不好使了,把所有的120偶电阻都去掉,除了主设备没有去掉,然后在A线接个2k电阻至vcc,B线接个2K电阻至GND,就又好使了,单独使用一个从设备时就有不好使了,我也是被晕了,总之有经验的人说是驱动问题. 现把网上的经验分享一下 以下是进行485布线时应遵循的一些规范或经验: ①严格遵循总线布线原则.一路总线(双线)从头走到尾.如果两个地

触摸事件之事件传递

iOS中的事件有3类,触摸事件(单点,多点,手势).传感器事件(加速度传感器)和远程控制事件.无论是哪种事件,都是系统本身先获得,是iOS系统来传给UIApplication的,由Application再决定交给谁去处理,所以如果我们要拦截事件,可以在UIApplication层面或者UIWindow层面去拦截. UIView是如何判定这个事件是否是自己应该处理的呢? iOS系统检测到一个触摸操作时会打包一个UIEvent对象,并放入Application的队列,Application从队列中取

Android 提供的一系列辅助系统开发工具

除了软件本身的代码之外,Android 还提供了一系列工具来辅助系统开发,这些主要的工具包括: aapt(AndroidAssetPackagingTool):用于建立zip兼容的包(zip.jar.apk),也可用于将资源编译到二进 制的 assets. adb(Android Debug Bridge,Android 调试桥):使用 adb 工具可以在模拟器或设备上安装应用程序的.apk 文件,并从命令行访问模拟器或设备.也可以用它把 Android 模拟器或设备上的应用程序代码和一个标准

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

addChild(boxC,30, kBoxC_Tag);                                                                                         ⑥ returntrue; } 我们在HelloWorld::init()函数中初始化了场景中的背景和三个方块精灵.代码第①~④行是创建并添加背景,图8-3所示的背景是由一个128x128纹理图片(BackgroundTile.png)反复贴图上,这样可以减少内存