禁用ViewPager滚动动画

5

这里的代码中,我有一个设置了适配器的ViewPager。有没有办法禁用滚动动画,使其在我滑动时只是“跳转”到新页面?我不想在onTouchEventonInterceptTouchEvent中禁用整个滚动功能,只想禁用滑动动画。

mSectionsPagerAdapter = new SectionsPagerAdapter(getFragmentManager());

// Set up the ViewPager with the sections adapter.
mViewPager = (CustomViewPager) findViewById(R.id.pager);
mViewPager.setAdapter(mSectionsPagerAdapter);
4个回答

17

我不知道是否有一个干净的解决方案。但是你可以使用一个技巧,通过另一个transformer来撤销标准页面transformer。 NoPageTransformer看起来像这样:

private static class NoPageTransformer implements ViewPager.PageTransformer {
    public void transformPage(View view, float position) {
        if (position < 0) {
            view.setScrollX((int)((float)(view.getWidth()) * position));
        } else if (position > 0) {
            view.setScrollX(-(int) ((float) (view.getWidth()) * -position));
        } else {
            view.setScrollX(0);
        }
    }
}

要将它添加到您的ViewPager中,请调用:

mViewPager.setPageTransformer(false, new NoPageTransformer());

将适用于SDK版本16及以上。


太好了,这是完美的解决方案, 你能帮忙实现垂直视图吗? - Mohd Sakib Syed

2

Kotlin:

viewpager.setPageTransformer(false, FadePageTransformer())


inner class FadePageTransformer : ViewPager.PageTransformer {
    override fun transformPage(view: View, position: Float) {
        view.translationX = view.width * -position

        if (position <= -1.0f || position >= 1.0f) {
            view.alpha = 0.0f
            view.setVisibility(View.GONE);
        } else if (position == 0.0f) {
            view.alpha = 1.0f
            view.setVisibility(View.VISIBLE);
        } else {
            // position is between -1.0F & 0.0F OR 0.0F & 1.0F
            view.alpha = 1.0f - Math.abs(position)
            view.setVisibility(View.GONE);
        }
    }
}

3
在 else 块中,您应该设置 View.VISIBLE。 - D. Sergeev

0
viewPager.setPageTransformer(false, new NoPageTransformer());

private static class NoPageTransformer implements ViewPager.PageTransformer {
    public void transformPage(@NonNull View view, float position) {
        view.setTranslationX(view.getWidth() * -position);
        if (position <= -1.0f || position >= 1.0f) {
            view.setVisibility(View.GONE);
        } else if (position == 0.0f) {
            view.setVisibility(View.VISIBLE);
        } else {
            view.setVisibility(View.GONE);
        }
    }
}

0

被接受的答案仍然有滑动动画。我在搜索如何禁用用户滑动时,找到了以下实现方法:

1-重写ViewpageronInterceptTouchEventonTouchEvent方法。

2-创建自己的GestureDetector

3-检测滑动手势并使用setCurrentItem(item, false)方法。

ViewPager

public class ViewPagerNoSwipe extends ViewPager {
    private final GestureDetector gestureDetector;
    private OnSwipeListener mOnSwipeListener;

    public void setOnSwipeListener(OnSwipeListener onSwipeListener) {
        mOnSwipeListener = onSwipeListener;
    }

    public ViewPagerNoSwipe(@NonNull Context context) {
        super(context);
        gestureDetector = new GestureDetector(context, new GestureListener());

    }

    public ViewPagerNoSwipe(@NonNull Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
        gestureDetector = new GestureDetector(context, new GestureListener());


    }

    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        return true;
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        gestureDetector.onTouchEvent(ev);
        return false;
    }

    public 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 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) {
                            if(mOnSwipeListener!=null)
                            mOnSwipeListener.onSwipeRight();
                        } else {
                            if(mOnSwipeListener!=null)
                                mOnSwipeListener.onSwipeLeft();
                        }
                        result = true;
                    }
                } else if (Math.abs(diffY) > SWIPE_THRESHOLD && Math.abs(velocityY) > SWIPE_VELOCITY_THRESHOLD) {
                    if (diffY > 0) {
                        if(mOnSwipeListener!=null)
                            mOnSwipeListener.onSwipeBottom();
                    } else {
                        if(mOnSwipeListener!=null)
                            mOnSwipeListener.onSwipeTop();
                    }
                    result = true;
                }
            } catch (Exception exception) {
                exception.printStackTrace();
            }
            return result;
        }
    }

    public interface OnSwipeListener {

         void onSwipeRight();

        void onSwipeLeft();

        void onSwipeTop();

        void onSwipeBottom();
    }
}

当您设置ViewPager时,请设置swipeListener

postsPager.setOnSwipeListener(new ViewPagerNoSwipe.OnSwipeListener() {
            @Override
            public void onSwipeRight() {

              postsPager.setCurrentItem(postsPager.getCurrentItem() + 1,false);

            }

            @Override
            public void onSwipeLeft() {

            postsPager.setCurrentItem(postsPager.getCurrentItem() - 1, false);

            }
             ...
           }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接