拖拉的惯性运动

时间:2013-05-21 20:15:25

标签: java android performance drag-and-drop direction

我正在研究一个拖放代码,到目前为止它工作正常,但我需要能够根据手指滑动的速度和方向进行识别和操作(即使手指已经上移也要继续移动) ,又称增加惯性)。更好的例子就是facebook chatheads:

enter image description here

3 个答案:

答案 0 :(得分:2)

我必须使用一些自定义的onTouchEvent侦听器,并使用VelocityTracker来确定运动的距离。然后我只使用翻译动画师并覆盖onAnimationEnd将实际视图边距设置为新位置,就是这样:)

答案 1 :(得分:0)

在滑动触控列表器上使用自定义

public class OnSwipeTouchListener implements OnTouchListener {
private final GestureDetector gestureDetector = new GestureDetector(new GestureListener());

public boolean onTouch(final View view, final MotionEvent motionEvent) {

    return gestureDetector.onTouchEvent(motionEvent);
}

private final class GestureListener extends SimpleOnGestureListener {

    private static final int SWIPE_THRESHOLD = 100;
    private static final int SWIPE_VELOCITY_THRESHOLD = 100;

    @Override
    public boolean onDown(MotionEvent e) {
        return true;
    }

    @Override
    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
        boolean result = false;
        try {
            float diffY = e2.getY() - e1.getY();
            float diffX = e2.getX() - e1.getX();
            if (Math.abs(diffX) > Math.abs(diffY)) {
                if (Math.abs(diffX) > SWIPE_THRESHOLD && Math.abs(velocityX) > SWIPE_VELOCITY_THRESHOLD) {
                    if (diffX > 0) {
                        onSwipeRight();
                    } else {
                        onSwipeLeft();
                    }
                }
            } else {
                if (Math.abs(diffY) > SWIPE_THRESHOLD && Math.abs(velocityY) > SWIPE_VELOCITY_THRESHOLD) {
                    if (diffY > 0) {
                        onSwipeBottom();
                    } else {
                        onSwipeTop();
                    }
                }
            }
        } catch (Exception exception) {
            exception.printStackTrace();
        }
        return result;
    }
}

public boolean onSwipeRight() {
    return false;
}

public boolean onSwipeLeft() {
    return false;
}

public boolean onSwipeTop() {
    return false;
}

public boolean onSwipeBottom() {
    return false;
}}

您可以为SWIPE THRESHOLD和SWIPE VELOCITY THRESHOLD设置自己的值

您可以使用以下代码

来实现它
        findViewById(R.id.inner_content).setOnTouchListener(new OnSwipeTouchListener(){
         public boolean onSwipeTop() {
                Toast.makeText(SampleActivity.this, "top", Toast.LENGTH_SHORT).show();
                return true;
            }
            public boolean onSwipeRight() {
                Toast.makeText(SampleActivity.this, "right", Toast.LENGTH_SHORT).show();                    
                return true;
            }
            public boolean onSwipeLeft() {
                Toast.makeText(SampleActivity.this, "left", Toast.LENGTH_SHORT).show();
                return true;
            }
            public boolean onSwipeBottom() {
                Toast.makeText(SampleActivity.this, "bottom", Toast.LENGTH_SHORT).show();
                return true;
            }
    });

答案 2 :(得分:-2)

您可以通过覆盖SimpleOnGestureListener

来使用这段代码
package com.ViewFlipperDemo;

import android.app.Activity;
import android.content.Context;
import android.content.res.Configuration;
import android.gesture.GestureLibraries;
import android.gesture.GestureLibrary;
import android.gesture.GestureOverlayView;
import android.gesture.GestureOverlayView.OnGesturePerformedListener;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.View;
import android.view.GestureDetector.SimpleOnGestureListener;
import android.view.View.OnTouchListener;
import android.view.animation.AnimationUtils;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.ViewFlipper;

//import com.ViewFlipperDemo.ViewFlipperSampleActivity.MyGestureDetector;

public class FlipActivity extends Activity {

    private static final int SWIPE_MIN_DISTANCE = 60;
    private static final int SWIPE_THRESHOLD_VELOCITY = 100;

    private ViewFlipper vf;
    private Context mContext;
    private final GestureDetector detector = new GestureDetector(
            new MyGestureDetector());


    @Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {
        return true;
    }
    @Override
    public boolean onKeyLongPress(int keyCode, KeyEvent event) {
        return true;
    }
    @Override
    public boolean onKeyUp(int keyCode, KeyEvent event) {
        return true;
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        Configuration config = getResources().getConfiguration();
        config.hardKeyboardHidden=1;
        mContext = this;
        vf = (ViewFlipper) this.findViewById(R.id.vfShow);
        vf.setOnTouchListener(new OnTouchListener() {
            @Override
            public boolean onTouch(final View view, final MotionEvent event) {
                detector.onTouchEvent(event);
                return true;
            }
        });

        vf.addView(addImageView(R.drawable.scott));
        vf.addView(addImageView(R.drawable.ricardo));

    }

    View addImageView(int resId) {
        ImageView iv = new ImageView(this);
        iv.setImageResource(resId);

        return iv;
    }

    class MyGestureDetector extends SimpleOnGestureListener {
        GestureLibrary mLibrary;

        Canvas cv=new Canvas();
        Paint pp=new Paint();



        public boolean onDoubleTap(MotionEvent e1){


            return false;

        }

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


            /*  mLibrary = GestureLibraries.fromRawResource(this, R.raw.gestures);
                   if (!mLibrary.load()) {
                     finish();
                   }

                   GestureOverlayView gestures = (GestureOverlayView) findViewById(R.id.gestures);
                   gestures.addOnGesturePerformedListener((OnGesturePerformedListener) this);
                */pp.setColor(Color.RED);

                // right to left swipe
                if (e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE
                        && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {



                    cv.drawLine(e1.getX(), e1.getY(), e2.getX(), e1.getY(),pp);

                    Toast.makeText(FlipActivity.this,"jj", 
                           Toast.LENGTH_SHORT).show();
                //  vf.setInAnimation(AnimationUtils.loadAnimation(mContext,R.anim.left_in));
            //  vf.setOutAnimation(AnimationUtils.loadAnimation(mContext,R.anim.left_out));
                //  vf.showNext();
                    return true;
                } else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE
                        && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
                    //Toast.makeText(FlipActivity.this,"hi", 
                           // Toast.LENGTH_SHORT).show();

                    cv.drawLine(e1.getX(), e1.getY(), e2.getX(), e1.getY(),pp);
                //  vf.setInAnimation(AnimationUtils.loadAnimation(mContext,R.anim.right_in));
                //  vf.setOutAnimation(AnimationUtils.loadAnimation(mContext,R.anim.right_out));
                //  vf.showPrevious();
                    return true;
                }

            } catch (Exception e) {
                e.printStackTrace();
            }

            return false;
        }
    }
}