Android 获取触摸点坐标,判断滑动方向,滑动距离,滑动速度,缩放手势

activity 或 fragment 实现接口  View.OnTouchListener

如:public class MyFragment extends Fragment implements View.OnTouchListener{

重写实现方法

    @Override
    public boolean onTouch(View v, MotionEvent event) {
        //继承了Activity的onTouchEvent方法,直接监听点击事件
        if(event.getAction() == MotionEvent.ACTION_DOWN) {
            //当手指按下的时候
            x1 = event.getX();
            y1 = event.getY();
        }
        if(event.getAction() == MotionEvent.ACTION_MOVE) {
            //当手指移动的时候
            x2 = event.getX();
            y2 = event.getY();
            if(y1 - y2 > 50) {
                Toast.makeText(MyServiceTestActivity.this, "向上滑", Toast.LENGTH_SHORT).show();
            } else if(y2 - y1 > 50) {
                Toast.makeText(MyServiceTestActivity.this, "向下滑", Toast.LENGTH_SHORT).show();
            } else if(x1 - x2 > 50) {
                Toast.makeText(MyServiceTestActivity.this, "向左滑", Toast.LENGTH_SHORT).show();
            } else if(x2 - x1 > 50) {
                Toast.makeText(MyServiceTestActivity.this, "向右滑", Toast.LENGTH_SHORT).show();
            }
        }
        if (event.getAction()==MotionEvent.ACTION_UP){
            Log.i("Lgq","sssssssll离开了lllll==");
//            updview(nowpersion);
        }
        return super.onTouchEvent(event);
//        return false;
    }

view设置监听

slv = (ScrollListenerView)findViewById(R.id.slv);

slv.setOnTouchListener(this);

分发二:重写方法

@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
    if (ev.getAction()==MotionEvent.ACTION_UP){
        LgqLogutil.e("动啦啦啦啦");
    }
    return super.dispatchTouchEvent(ev);
}

滑动速度:放在MotionEvent.ACTION_MOVE里

VelocityTracker mVelocityTracker = VelocityTracker.obtain();

mVelocityTracker.addMovement(ev);

mVelocityTracker.computeCurrentVelocity(1000);

float xVelocity = mVelocityTracker.getXVelocity();//速度
xVelocity = Math.abs(xVelocity);//去绝对值。向左滑,值为负数

获取最多速度

float  sudu;
if (sudu < xVelocity) {
    sudu = xVelocity;
}

缩放手势获取

double nLenStart = 0;

@Override
public boolean onTouchEvent(MotionEvent event) {

    int nCnt = event.getPointerCount();

    if ((event.getAction() & MotionEvent.ACTION_MASK) == MotionEvent.ACTION_POINTER_DOWN && 2 == nCnt)//<span style="color:#ff0000;">2表示两个手指</span>
    {

        for (int i = 0; i < nCnt; i++) {
            float x = event.getX(i);
            float y = event.getY(i);

            Point pt = new Point((int) x, (int) y);

        }

        int xlen = Math.abs((int) event.getX(0) - (int) event.getX(1));
        int ylen = Math.abs((int) event.getY(0) - (int) event.getY(1));

        nLenStart = Math.sqrt((double) xlen * xlen + (double) ylen * ylen);


    } else if ((event.getAction() & MotionEvent.ACTION_MASK) == MotionEvent.ACTION_POINTER_UP && 2 == nCnt) {

        for (int i = 0; i < nCnt; i++) {
            float x = event.getX(i);
            float y = event.getY(i);

            Point pt = new Point((int) x, (int) y);

        }

        int xlen = Math.abs((int) event.getX(0) - (int) event.getX(1));
        int ylen = Math.abs((int) event.getY(0) - (int) event.getY(1));

        double nLenEnd = Math.sqrt((double) xlen * xlen + (double) ylen * ylen);

        if (nLenEnd > nLenStart)//通过两个手指开始距离和结束距离,来判断放大缩小
        {
            LgqLogPlus.e("放大");
            setZoom();
        } else {
            LgqLogPlus.e("缩小");
            setZoomjian();
        }
    }
    return super.onTouchEvent(event);
}
  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个相对复杂的问题,需要一定的Android开发经验和知识。我会简单地讲解一下实现的大致思路和步骤。 1. 自定义LayoutManager 首先需要自定义一个LayoutManager,它会负责RecyclerView中每个item的布局排列和滚动。在这个LayoutManager中,我们需要重载一些方法,例如`onLayoutChildren()`,`scrollHorizontallyBy()`,`generateDefaultLayoutParams()`等。这些方法的具体实现会根据我们的需求而不同。其中,`onLayoutChildren()`方法负责测量和布局RecyclerView中的每一个ItemView,`scrollHorizontallyBy()`方法负责水平滚动RecyclerView,`generateDefaultLayoutParams()`方法负责生成默认的LayoutParams。 2. 实现弧形效果 要实现弧形效果,我们需要使用贝塞尔曲线。具体来说,我们可以通过计算贝塞尔曲线上的来实现在RecyclerView中弧形排列ItemView。这个过程可以在`onLayoutChildren()`方法中实现。我们可以通过计算每个ItemView的位置和角度来获得它的坐标,然后将这些坐标传递给View进行布局。 3. 实现滑动放大效果 要实现滑动放大效果,我们可以在`scrollHorizontallyBy()`方法中监听RecyclerView的滑动距离,然后根据距离计算每个ItemView的缩放比例。具体来说,我们可以在滑动过程中计算每个ItemView的中心和RecyclerView的中心之间的距离,然后根据距离计算缩放比例。我们可以使用`setScaleX()`和`setScaleY()`方法来设置ItemView的缩放比例。 以上是实现弧形以及滑动放大效果RecyclerView的大致思路和步骤。具体的实现过程中还需要考虑很多细节问题,例如ItemView的位置和角度计算、动画效果的处理等等。如果您需要更详细的信息,请参考相关的开发文档或者查找相关的示例代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值