quick的sample代码整理(一):触摸事件(上)


1. 多点触摸 (2.2.6)

1.1 多点触摸的基础使用

简化流程:

  • 开启触摸
  • 选择触摸模式
  • 设置触摸监听事件

详细代码:

self.sprite:setTouchEnabled(true)
self.sprite:setTouchMode(cc.TOUCH_MODE_ALL_AT_ONCE) -- 多点
--self.sprite:setTouchMode(cc.TOUCH_MODE_ONE_BY_ONE) -- 单点(默认模式)
  • event.name 为触摸事件的状态:began, moved, ended, cancelled, added(仅限多点触摸), removed(仅限多点触摸)

  • 多点触摸时,event.points保存的为多个触摸点,所以需要遍历每个触摸点来对触摸点进行特殊化处理

self.sprite:addNodeEventListener(cc.NODE_TOUCH_EVENT, function(event)
 if event.name == "began" or event.name == "added" then
            self.touchIndex = self.touchIndex + 1
            for id, point in pairs(event.points) do
                --对每个点进行处理
            end
        elseif event.name == "moved" then
            for id, point in pairs(event.points) do 
            end
        elseif event.name == "removed" then
            for id, point in pairs(event.points) do
                self.cursors[id]:removeSelf()
                self.cursors[id] = nil
            end
        else
            for _, cursor in pairs(self.cursors) do
                cursor:removeSelf()
            end
            self.cursors = {}
        end
end
1.2 保证触摸在矩形范围内才有效
  • 给当前精灵绘制一个矩形区域
  • 取得矩形区域
  • 判断触摸点是否在矩形区域

详细代码如下:
画出矩形范围,加入父节点

function drawBoundingBox(parent, target, color)
    local cbb = target:getCascadeBoundingBox()
    local left, bottom, width, height = cbb.origin.x, cbb.origin.y, 
                                        cbb.size.width, cbb.size.height
    local points = {
        {left, bottom},
        {left + width, bottom},
        {left + width, bottom + height},
        {left, bottom + height},
        {left, bottom},
    }
    local box = display.newPolygon(points, 1.0)
    box:setLineColor(color)
    parent:addChild(box, 1000)
end

取得矩形并且判断触摸点是否在矩形内

local rect = self.sprite:getBoundingBox()
if rect:containsPoint(cc.p(point.x, point.y)) then
  -- 检查触摸点的位置是否在矩形内
end
1.3 触摸捕获事件

什么是触摸捕获事件
它是触摸事件的第一个阶段,如果事件返回结果为false,就不触发触摸事件

触摸捕获事件的性质

  • 触摸捕获事件是默认开启的 setTouchCaptureEnabled(true)
  • 触摸捕获事件优先级高于触摸事件,并且有权不分发给触摸事件响应

触摸捕获事件的流程

  1. 遍历所有响应触摸的节点,找出显示层级最高(zOrder高到低),并且其触摸区域包含触摸位置的节点Node,标记为TargeNode
  2. 检查TargeNode是否有开启触摸捕获,如果返回false,重复1
  3. 从TargeNode的根节点(一般为Sence)开始,检查cc.NODE_TOUCH_CAPTURE_EVENT事件的返回结果,任何一个节点返回false都会阻止事件在TargeNode上触发。重复123

以下是cc.NODE_TOUCH_CAPTURE_EVENT的事件监听

self.button2:addNodeEventListener(cc.NODE_TOUCH_CAPTURE_EVENT, function(event)
        printf("%s %s [CAPTURING]", "button2", event.name)
        return true
end)
1.4 触摸事件的流程

触摸事件分为三个阶段:capturing(捕获) targeting(触发) bubbling(冒泡或传递)

触发流程
在TargetNode上触发事件,响应自己的触摸事件,如began,moved,ended等

冒泡流程
在TargetNode完成事件响应后,检查它是否将触摸吞噬(isTouchSwallowEnabled()),如果有,就不再将事件往下传递

1.5 禁用触摸

如果禁用某个节点的触摸事件,它的子节点仍旧响应触摸。所以如果当我们需要禁止对话框中的所有 Node 响应触摸,那么就要禁止对话框 Node 捕获事件(setTouchCaptureEnabled(false))

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容

  •   JavaScript 与 HTML 之间的交互是通过事件实现的。   事件,就是文档或浏览器窗口中发生的一些特...
    霜天晓阅读 3,470评论 1 11
  • 事件是什么,可以用来做什么,什么时候用到它? 事件,就是文档或浏览器窗口中发生的一些特定的交互瞬间。JavaScr...
    茂茂爱吃鱼阅读 1,506评论 0 16
  • 好奇触摸事件是如何从屏幕转移到APP内的?困惑于Cell怎么突然不能点击了?纠结于如何实现这个奇葩响应需求?亦或是...
    Lotheve阅读 56,606评论 51 597
  • 在iOS开发中经常会涉及到触摸事件。本想自己总结一下,但是遇到了这篇文章,感觉总结的已经很到位,特此转载。作者:L...
    WQ_UESTC阅读 5,987评论 4 26
  • 有些工作有待完成,时间貌似够用,还有一笔债务要去付清,然后生活就会开始,最后我终于明白,这些障碍,正是我的生活。—...
    温姬拉阅读 1,521评论 0 0