zoukankan      html  css  js  c++  java
  • Cocos Creator Touch_End的触发条件 (Mouse事件)

    参考:

    简书:Touch_end事件的触发时机

    Cocos教程:系统内置事件

    Touch_End的触发条件

    本来想做个虚拟摇杆,在摇杆UI上按下时摇杆运作,在任意舞台位置松开时摇杆停止。

    但是无法检测到舞台松开的touch_end事件。

     以下代码

            //在摇杆上按下
            this.vj.on(cc.Node.EventType.TOUCH_START, this.onTouchStart, this);
            //在舞台上移动
            this.canvs.on(cc.Node.EventType.TOUCH_MOVE, this.onTouchMove, this);
            //在舞台上松开
            this.canvas.on(cc.Node.EventType.TOUCH_END, this.onTouchEnd, this);
            //在舞台上松开
            this.canvas.on(cc.Node.EventType.TOUCH_CANCEL, this.onTouchCancel, this);
    

    结果是

    在摇杆区域内: touch_start 有效    -->   touch_move有效   -->  touch_end有效 --> touch_cancel无效

    在摇杆区域外:  touch_start 无效  -->   touch_move有效  --->  touch_end有效 -->touch_cancel无效

    在摇杆区域内点击,移动到摇杆区域外松开:  touch_start有效  --> touch_move有效  --> touch_end无效 --> touch_cancel有效

     

    玩家操作虚拟摇杆,然后手指移动到了摇杆区域外松开,就检测不到touch_end事。

    所以最终玩家松开的操作得用touch_end和touch_cancel共同检测

    用touch_end事件来监听摇杆区域内的松开情况

    用touch_cancel事件来监听摇杆区域外的松开情况

    在网上查了下具体解释

    TOUCH_START:按下即会触发该事件;
    
    TOUCH_MOVE:手指在屏幕上移动会触发该事件;
    
    TOUCH_CANCEL:在某些特定情况下,CocosCreator会判定该事件失效,即不能正常完成START-END的流程,这时会触发该事件,这些情况已知包括:
    
    1.手指按下(TOUCH_START)——手指滑动了较长的距离,但没有离开接收事件的节点(TOUCH_MOVE)——手指离开屏幕,本次判定为(TOUCH_CANCEL)
    
    2,手指按下(TOUCH_START)——手指滑动离开了接收事件节点的感知范围(TOUCH_MOVE)——手指离开屏幕,判定为(TOUCH_CANCEL)
    
    TOUCH_END:本次触摸基本按照START-END的顺序结束了,手指离开屏幕时会触发该事件,这些情况已知包括:
    

    Mouse事件

    鼠标事件有如下。但是这个事件在pc上能用。手机上没法用。基本用不上了。。。

  • 相关阅读:
    Linux内核从原理到代码详解
    linux内核研究-8-块设备I/O层
    《Linux内核分析》课程总结
    Nginx 重写规则指南1
    Nginx初探
    Nginx源码分析:3张图看懂启动及进程工作原理
    nginx源码分析 +redis的那些事儿
    I/O 模型及其设计模式
    高并发性能调试经验分享
    myawr
  • 原文地址:https://www.cnblogs.com/gamedaybyday/p/13047112.html
Copyright © 2011-2022 走看看