Android高级UI GestureDetector监听各种手势

原创 2016年05月30日 13:18:41

内容

第一部分:介绍GestureDetector
第二部分:改造之前用ViewFlipper实现的实例,使用GestureDetector实现图片切换功能。

要点

  1. 实现接口OnTouchListener,在onTouch()方法中由GestureDetector接管事件
  2. 接口OnGestureListener
  3. 接口OnDoubleTapListener
  4. 静态类SimpleOnGestureListener
    实现了2、3两个接口,却没有做具体事情。可以继承该类,需要哪个就override哪个部分。

xml

一般的布局即可

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/gesture_detector_linearlayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.feather.androiddemos.GestureDetectorActivity">

</LinearLayout>

Java中使用GestureDetector

推荐使用SimpleOnGestureListener

//实现OnTouchListener
public class GestureDetectorActivity extends AppCompatActivity implements View.OnTouchListener{

    private LinearLayout linearLayout;
    private GestureDetector gestureDetector;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_gesture_detector);

        linearLayout = (LinearLayout) findViewById(R.id.gesture_detector_linearlayout);//获取该布局
        linearLayout.setOnTouchListener(this);//设置监听器

        //获取GestureDetector
        gestureDetector = new GestureDetector(this,
                new SimpleOnGestureListener() //下面实现的class(类)
        );
    }

    @Override
    public boolean onTouch(View v, MotionEvent event) {
        gestureDetector.onTouchEvent(event); //由GestureDetector进行接管,消耗掉event
        return false;
    }

    //继承静态类,重写相应方法
    class SimpleOnGestureListener extends GestureDetector.SimpleOnGestureListener{

         @Override//该方法就是按下时触发,此外还有近十种方法
        public boolean onDown(MotionEvent e) {
            Toast.makeText(GestureDetectorActivity.this, "onDown", Toast.LENGTH_SHORT).show();
            return super.onDown(e);
        }
    }
}

ViewFliper和GestureDetector实现图片切换

之前ViewFliper教程链接如下:http://blog.csdn.net/feather_wch/article/details/51535660

我们将在本教程基础上进行修改:
ViewFlipperActivity中置换为如下内容即可

public class ViewFlipperActivity extends AppCompatActivity implements View.OnTouchListener{

    ViewFlipper viewFlipper = null; //ViewFlipper控件
    GestureDetector gestureDetector = null;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_view_flipper);

        viewFlipper = (ViewFlipper) findViewById(R.id.ViewFlipper);//获取自动切换
        viewFlipper.setOnTouchListener(this);

        gestureDetector = new GestureDetector(this, new SimpleOnGestureListener()); //初始化GestureDetector
    }

    @Override
    public boolean onTouch(View v, MotionEvent event) { //触屏
        //使用GestureDetector

        gestureDetector.onTouchEvent(event); //GestureDetector接管触屏按键
        return false;
    }

    //继承静态类,重写相应方法
    class SimpleOnGestureListener extends GestureDetector.SimpleOnGestureListener{

        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {

            if(e2.getX() - e1.getX() > 100)//从左向右
            {
                //设置切换动画
                viewFlipper.setInAnimation(AnimationUtils.loadAnimation(ViewFlipperActivity.this, R.anim.push_right_in));
                viewFlipper.setOutAnimation(AnimationUtils.loadAnimation(ViewFlipperActivity.this, R.anim.push_right_out));
                //显示上一个View
                viewFlipper.showPrevious(); //从左向右,显示上一幅图片
            }else if(e1.getX() - e2.getX() > 100)
            {
                //设置切换动画
                viewFlipper.setInAnimation(AnimationUtils.loadAnimation(ViewFlipperActivity.this, R.anim.push_left_in));
                viewFlipper.setOutAnimation(AnimationUtils.loadAnimation(ViewFlipperActivity.this, R.anim.push_left_out));

                viewFlipper.showNext(); //从左向右,显示下一幅图片
            }
            return true;
        }

        public SimpleOnGestureListener() {
            super();
        }
    }
}
版权声明:本文为博主原创文章,可以转载,但恳请标注上转载自(猎羽)的博客并且附上链接,谢谢!

相关文章推荐

Android手势监听类GestureDetector

GestureDetector类及其用法 Android sdk 给我们提供了GestureDetector(Gesture:手势,Detector:识别)类,通过这个类我们可以识别很多的手势,...

Android手势监听类GestureDetector

GestureDetector类及其用法 Android sdk 给我们提供了GestureDetector(Gesture:手势,Detector:识别)类,通过这个类我们可以识别很多的手势,...

Android开发-自定义View-AndroidStudio(九)手势监听类GestureDetector

转载请注明出处:http://blog.csdn.net/iwanghang/ 觉得博文有用,请点赞,请评论,请关注,谢谢!~ 由于我自己对手势监听类没什么概念,用过很多次,但是没有完整的了解过,...

Android 简单的手势处理+监听的处理,用GestureDetector

添加手势识别监听步骤: 一、给相应的控件添加触摸监听事件, 二、利用GestureDetector转发这个触摸事件。 三、事先定义好一个实现simpleongestureListener这个监听的接口...

Android手势监听(GestureDetector类)

public class GestureTest extends Activity implements OnClickListener, OnGestureListener { // 定义手势检测...

触摸事件与手势监听--Android GestureDetector详解

目录 事件监听的方法 GestureDetector类 GestureDetector使用方法 GesturetDetector.OnGestureListener 接口 GesttureDetect...

Android中手势监听GestureDetector基础&android:onTouch()和onTouchEvent()的区别

最近做的2个东西中都碰到了需要对用户手势输入监听并做出一定的相应 抽空把这些基础实现做个记录 网上这方面资料也不少 这里说的手势监听只是简单的比如上滑,下滑,拖动等,而没有说到画图板这样的应用 当然...

手势监听 GestureDetector.SimpleOnGestureListener

前言当用户触摸屏幕的时候,会产生许多手势,例如down,up,scroll,filing等等,我们知道View类有个View.OnTouchListener内部接口,通过重写他的onTouch(Vie...

GestureDetector 手势监听,根据手势动态操作布局显示

1:需求向下滑动时布局隐藏掉一部分,向上滑动时候显示出来 大概样子如图的需求动态根据手势显示隐藏打赏的物品模块 2:做手势监听 在Android中,是由GestureDetector类来...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)