前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >OnGestureListener探索

OnGestureListener探索

作者头像
提莫队长
发布2019-02-21 11:38:05
4950
发布2019-02-21 11:38:05
举报
文章被收录于专栏:刘晓杰刘晓杰

最近要用到手势检测,所以重新温习了一下OnGestureListener

先看测试代码

代码语言:javascript
复制
public class MyView extends View implements OnGestureListener {
    private GestureDetector gestureDetector;

    public MyView(Context context, AttributeSet attrs) {
        super(context, attrs);
        gestureDetector = new GestureDetector(context, this);
        gestureDetector.setIsLongpressEnabled(true);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        return gestureDetector.onTouchEvent(event);
    }

    // Touch down时触发
    @Override
    public boolean onDown(MotionEvent e) {
        Log.e("onDown", "onDown");
        // 这里要改成true,表示该事件已被消费掉,否则无论什么手势都是onDown-onShowPress-onLongPress
        return true;
    }

    // Touchdown后过一会没有滑动先触发onShowPress再是onLongPress
    @Override
    public void onShowPress(MotionEvent e) {
        Log.e("onShowPress", "onShowPress");
    }

    // Touch了不移动一直Touch down时触发
    @Override
    public void onLongPress(MotionEvent e) {
        Log.e("onLongPress", "onLongPress");
    }

    // 在touch down后又没有滑动(onScroll),又没有长按(onLongPress),然后Touchup时触发
    // 类似于ACTION_UP
    @Override
    public boolean onSingleTapUp(MotionEvent e) {
        Log.e("onSingleTapUp", "onSingleTapUp");
        return false;
    }

    @Override
    public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,
            float distanceY) {
        Log.e("onScroll", "onScroll");
        return false;
    }

    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
            float velocityY) {
        Log.e("onFling", "onFling");
        return false;
    }
}

长按

这里写图片描述
这里写图片描述

注意,没有onSingleTapUp,可见只是类似于ACTION_UP,而不等同于ACTION_UP。ACTION_UP只要抬起就会检测到,onSingleTapUp必须是没有滑动没有长按

快速点击和慢速点击

这里写图片描述
这里写图片描述

慢速点击中间多了一个onShowPress

滑动

这里写图片描述
这里写图片描述
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016年10月20日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档