Android用户手势检测

简介: Android用户手势检测

GestureDetector这个类对外提供了两个接口和一个外部类


接口:OnGestureListener,OnDoubleTapListener


:第一个接口处理手势,第二个接口 处理 单击或者双击


内部类:SimpleOnGestureListene


: 这个外部类 就是 接口中的所有函数的集成,他包含了这两个接口里所有需要实现的函数,并且进行了重写,但是所有的方法体都是空的;该类是 static class ,程序员可以在外部继承这个类,重写里面的手势 方法。


1,使用接口


使用如下:


public class GestureListener implements GestureDetector.OnGestureListener ,
    GestureDetector.OnDoubleTapListener{
    private static final String TAG = "GestureListener";
    // 用户按下屏幕就会触发;
    @Override
    public boolean onDown(MotionEvent e) {
        Log.e(TAG, "onDown: 按下屏幕就会触发" );
        return false;
    }
    //用户按下屏幕,尚未松开或 者拖动 则会触发
    @Override
    public void onShowPress(MotionEvent e) {
        Log.e(TAG, "onShowPress: 按下屏幕,尚未松开或 者拖动" );
    }
    // 用户点击屏幕后松开,则会触发该事件
    @Override
    public boolean onSingleTapUp(MotionEvent e) {
        Log.e(TAG, "onSingleTapUp: 点击屏幕后松开" );
        return false;
    }
    /**
     * 用户按下屏幕,并拖动
     * @param distanceX x 轴滑动距离
     * @param distanceY y 轴滑动距离
     */
    @Override
    public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
        Log.e(TAG, "onScroll: 用户按下屏幕,并拖动" );
        return false;
    }
    // 用户长按屏幕,
    @Override
    public void onLongPress(MotionEvent e) {
        Log.e(TAG, "onLongPress:长按屏幕 " );
    }
    /**
     * 用户按下屏幕,快速移动后松开,
     * @param e1 按下的 event
     * @param e2 抬起的 event
     * @param velocityX x 轴上的移动速度 像素 每秒
     * @param velocityY y 轴上的移动速度 像素 每秒
     */
    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
        Log.e(TAG, "onFling: 用户按下屏幕,快速移动后松开," );
        return false;
    }
    //单击事件,
    @Override
    public boolean onSingleTapConfirmed(MotionEvent e) {
        Log.e(TAG, "onSingleTapConfirmed: 点击" );
        return false;
    }
    // 双击 事件
    @Override
    public boolean onDoubleTap(MotionEvent e) {
        Log.e(TAG, "onDoubleTap: 双击" );
        return false;
    }
    // 双击 间隔中发生的动作
    @Override
    public boolean onDoubleTapEvent(MotionEvent e) {
        Log.e(TAG, "onDoubleTapEvent: 双击中的间隔" );
        return false;
    }
}


上面实现了 两个接口 重写了所有的方法,注释已经写在方法上面了。


@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //创建 gestureDetector 对象,传入 onGestureListener 的实例
        mGestureDetector = new GestureDetector(new GestureListener());
        CustomVolumeControlBar controlBar = findViewById(R.id.controlBar);
        //触摸事件
        controlBar.setOnTouchListener(this);
        //获取焦点
        controlBar.setFocusable(true);
        //启用或者禁用 单击事件
        controlBar.setClickable(true);
        //启用或者禁用 长按事件
        controlBar.setLongClickable(true);
    }
    /**
     * 通过调用 GestureDetector 的 onTouchEvent()方法,将捕捉到的 MotionEvent 交给 GestureDetector
     * 来分析 是否由合适的 callback 函数来处理用户的手势
     */
    @SuppressLint("ClickableViewAccessibility")
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        return mGestureDetector.onTouchEvent(event);
    }


上面对一个 自定义View 进行了手势检测。手势检测的接口 和 双击 的接口 都已经实现,可以使用


2,使用内部类


使用内部类的方式,使用这种方式 可以根据情况,用到那个方法就重写那个方法:


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    //创建 gestureDetector 类的 静态内部类来实现,可以重写任意的方法
    mGestureDetector = new GestureDetector(new GestureDetector.SimpleOnGestureListener(){
        final int FLING_MIN_DISTANCE = 100, FLING_MIN_VELOCITY = 200;
        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
            //小例子:判断是左滑 还是右滑
            if (e1.getX() - e2.getX() > FLING_MIN_DISTANCE && Math.abs(velocityX) > FLING_MIN_VELOCITY){
                Log.e(TAG, "onFling: 左滑"+e1.getX()+"------"+e2.getX() );
            }else if (e2.getX() - e1.getX() > FLING_MIN_DISTANCE && Math.abs(velocityX) > FLING_MIN_VELOCITY){
                Log.e(TAG, "onFling: 右滑 "+e1.getX()+"------"+e2.getX()  );
            }
            return false;
        }
        @Override
        public boolean onDoubleTapEvent(MotionEvent e) {
            Log.e(TAG, "onDoubleTapEvent: 双击" );
            return false;
        }
    });
    CustomVolumeControlBar controlBar = findViewById(R.id.controlBar);
    //触摸事件
    controlBar.setOnTouchListener(this);
    //获取焦点
    controlBar.setFocusable(true);
    //启用或者禁用 单击事件
    controlBar.setClickable(true);
    //启用或者禁用 长按事件
    controlBar.setLongClickable(true);
}
/**
 * 通过调用 GestureDetector 的 onTouchEvent()方法,将捕捉到的 MotionEvent 交给 GestureDetector
 * 来分析 是否由合适的 callback 函数来处理用户的手势
 */
@SuppressLint("ClickableViewAccessibility")
@Override
public boolean onTouch(View v, MotionEvent event) {
    return mGestureDetector.onTouchEvent(event);
}
相关文章
|
4月前
|
XML 监控 Java
Android App开发之事件交互Event中检测软键盘和物理按键讲解及实战(附源码 演示简单易懂)
Android App开发之事件交互Event中检测软键盘和物理按键讲解及实战(附源码 演示简单易懂)
135 0
|
10月前
|
API Android开发
使用Android的Service实现后台定时检测并重启应用
使用Android的Service实现后台定时检测并重启应用
|
11月前
|
Android开发
全网最优雅安卓列表项可见性检测
全网最优雅安卓列表项可见性检测
117 0
|
Java Android开发
Android体系课之--LeakCanary内存泄露检测原理解析
#### 内存泄露 不需要的对象实例,无法被垃圾回收,比如被静态片段保留,就说可能发生内存泄露 ##### 常见场景: - 1.不清楚fragment视图的字段的情况下,将fragment添加到backstack中 - 2.Activity以context的形式被添加到一些类中,比如静态类,则gc无法清除,如Activity被非静态内部类Handler引用 - 3.注册一个监听器,广播接收器或者RxJava订阅时,引用了一个生命周期的对象,生命周期结束后,没有取消注册
|
监控 Java API
Android IO 框架 Okio 的实现原理,如何检测超时?
在上一篇文章里,我们聊到了 Square 开源的 I/O 框架 Okio 的三个优势:精简且全面的 API、基于共享的缓冲区设计以及超时机制。前两个优势已经分析过了,今天我们来分析 Okio 的超时检测机制。
133 0
|
Android开发
android 检测外接键盘并设置输入法布局
android 检测外接键盘并设置输入法布局
337 0
|
Android开发
android 修改输入法中拼写检测默认值
android 修改输入法中拼写检测默认值
57 0
|
机器学习/深度学习 算法 自动驾驶
[Paddle Detection]基于PP-PicoDet行车检测(完成安卓端部署)
基于PP-PicoDet行车检测(完成安卓端部署)_哔哩哔哩_bilibili基于视觉深度学习的自动驾驶场景,旨在对车载摄像头采集的视频数据进行道路场景解析(行车检测),为自动驾驶提供一种解决思路。该项目使用bdd100k_car数据集训练,并完成了安卓部署。现如今,汽车在日益普及人们的生活,再给人们带来极大便利的同时也造成了拥堵的交通更为频发的交通事故。通过行车检测不仅能够更好的帮助司机检查路况,并且还能够更好的规化当前的路程管理,减轻道路的拥堵情况。 在车辆驾驶中主要考验的是司机如何应对其他行驶车辆的可
311 0
[Paddle Detection]基于PP-PicoDet行车检测(完成安卓端部署)
|
消息中间件 存储 设计模式
Android卡顿优化 | 自动化卡顿检测方案与优化(AndroidPerformanceMonitor / BlockCanary)
Android卡顿优化 | 自动化卡顿检测方案与优化(AndroidPerformanceMonitor / BlockCanary)
|
开发工具 Android开发 内存技术
产品百科 |RTC Android SDK 如何进行设备检测?
本文为您介绍了阿里云 RTC 的设备检测和管理功能,您可以在加入频道之前检查硬件设备是否能正常工作。
产品百科 |RTC Android SDK 如何进行设备检测?