【问题标题】:Moving a RecyclerView via Touch or Gesture Recognition通过触摸或手势识别移动 RecyclerView
【发布时间】:2017-04-23 07:55:31
【问题描述】:

我正在尝试移动和增长 RecyclerView,以便内容基于触摸输入占据全屏。我希望 RecyclerView 保持左右滚动的能力。

我无法让 GestureDetector 与 RecyclerView 一起正常工作。捕捉 onScrollChange 不起作用,因为它可能无法滚动。我尝试 onTouchEvent 但结果相当错误。有人有什么建议吗?

回购:https://github.com/CubanAzcuy/Animation-Test

        mListView.setOnTouchListener(new View.OnTouchListener() {
        Float mHistoricX = null;
        Float mHistoricY = null;

        Float mHistoricX2 = null;
        Float mHistoricY2 = null;

        int mScrollDirection = 0;
        //1 = Left Right
        //2 = Up Down

        @Override
        public boolean onTouch(View v, MotionEvent e) {
            Log.d("TAG", "eX: " + e.getX() + " eY: " + e.getY());
            switch (e.getAction()) {

                    case MotionEvent.ACTION_UP:
                        Log.d("TAG", "ACTION_UP");

                        mHistoricX = null;
                        mHistoricY = null;
                        mScrollDirection = 0;
                        break;
                    case MotionEvent.ACTION_MOVE:
                        Log.d("TAG", "ACTION_MOVE");
                        if(mHistoricX == null || mHistoricY == null) {
                            mHistoricX = e.getX();
                            mHistoricY = e.getY();
                        } else {
                            if(mScrollDirection == 0) {
                                float tempX = Math.abs(mHistoricX - e.getX());
                                float tempy = Math.abs(mHistoricY - e.getY());

                                if(tempX >= tempy) {
                                    mScrollDirection = 1;
                                } else {
                                    mScrollDirection = 2;
                                }

                                mHistoricX2 =  mHistoricX - e.getX();
                                mHistoricY2 = mHistoricY - e.getY();

                            } else {
                                mHistoricX2 =  mHistoricX - e.getX();
                                mHistoricY2 = mHistoricY - e.getY();
                                Log.d("TAG", "X: " + mHistoricX2 + " Y: " + mHistoricY2);

                                mHistoricX = e.getX();
                                mHistoricY = e.getY();
                            }

                        }
                        break;
                    default:
                        break;

                }
            if(mScrollDirection == 2){
                mListView.animate().setDuration(0).xBy(-mHistoricX2).yBy(-mHistoricY2);
                return true;
            }

            return false;
        }
    });

【问题讨论】:

    标签: android android-recyclerview android-animation


    【解决方案1】:

    在一个类中移动下面的代码。 {

    public class OnSwipeTouchListener implements View.OnTouchListener {
    
        private final GestureDetector gestureDetector;
    
        public OnSwipeTouchListener (Context ctx){
            gestureDetector = new GestureDetector(ctx, new GestureListener());
        }
    
        @Override
        public boolean onTouch(View v, MotionEvent event) {
            return gestureDetector.onTouchEvent(event);
        }
    
        private final class GestureListener extends GestureDetector.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 onSingleTapUp(MotionEvent e) {
                onClick();
                return super.onSingleTapUp(e);
            }
    
            @Override
            public boolean onDoubleTap(MotionEvent e) {
                onDoubleClick();
                return super.onDoubleTap(e);
            }
    
            @Override
            public void onLongPress(MotionEvent e) {
                onLongClick();
                super.onLongPress(e);
            }
    
            @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();
                            }
                        }
                        result = true;
                    }
                    else if (Math.abs(diffY) > SWIPE_THRESHOLD && Math.abs(velocityY) > SWIPE_VELOCITY_THRESHOLD) {
                        if (diffY > 0) {
                            onSwipeBottom();
                        } else {
                            onSwipeTop();
                        }
                    }
                    result = true;
    
                } catch (Exception exception) {
                    exception.printStackTrace();
                }
                return result;
            }
        }
    
        public void onSwipeRight() {
        }
    
        public void onSwipeLeft() {
        }
    
        public void onSwipeTop() {
        }
    
        public void onSwipeBottom() {
        }
    
        public void onClick() {
    
        }
    
        public void onDoubleClick() {
    
        }
    
        public void onLongClick() {
    
        }
    }
    

    }

    使用下面提到的这个监听器。 将触摸侦听器设置为行文件的父视图。 {

    holder.relMainOfRow.setOnTouchListener(new OnSwipeTouchListener(getActivity()) {
    
                    @Override
                    public void onClick() {
                        super.onClick();
    
                    }
    
                    @Override
                    public void onLongClick() {
                        super.onLongClick();
    
    
                    }
    
    
    
                    public void onSwipeTop() {
    
                    }
    
                    public void onSwipeRight() {
    
                    }
    
                    public void onSwipeLeft() {
    
                    }
    
                    public void onSwipeBottom() {
    
                    }
                });
    

    }

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2018-08-19
      • 1970-01-01
      • 1970-01-01
      • 2018-12-31
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多