圆形(垂直)ViewPager-错误的顺序和UI问题

时间:2019-02-08 18:00:45

标签: android android-fragments android-viewpager

我正在尝试设置一个垂直的圆形(请参见下面的类)viewpager,但是它并不能像我想要的那样正常工作。

使用链接https://github.com/BloodWorking/TestCircularViewPager查看我的意思的gif文件:

(Downscroll.gif)在开始/第一次向下滚动时,它会再次转到第1页而不是第2页。在这第一次后,它是正常的(第1至2页)。

(Upscroll.gif)在开始/第一次向上滚动时,它转到第2页而不是第3页。它跳过了它。第一次我从第1页向上滚动到第3页之后,在短时间内可以看到第3页,然后消失(只有可见性)。

我不知道为什么以及如何解决它。我将不胜感激。

我认为我对CircularViewPager的解决方案可能不是最好的,所以我也会考虑其他解决方案;)。

    mViewPager.setAdapter(mSectionsPagerAdapter);
    mViewPager.setCurrentItem(1, false);
    mViewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
        }

        @Override
        public void onPageSelected(int position) {
            mCurrentPosition = position; 
        }

        @Override
        public void onPageScrollStateChanged(int state) {

            if (mCurrentPosition == 0)
                mViewPager.setCurrentItem(lastPageIndex - 1, false); 

           //lastPageIndex is 4 (global variable)

            if (mCurrentPosition == lastPageIndex)
                mViewPager.setCurrentItem(1, false);

        }
    });




public class SectionsPagerAdapter extends FragmentPagerAdapter {

    public SectionsPagerAdapter(FragmentManager fm) {
        super(fm);
    }

    @Override
    public Fragment getItem(int position) {
        switch (position) {
            case 0: return PlaceholderFragment.newInstance(3);
            case 1: return PlaceholderFragment.newInstance(1);
            case 2: return PlaceholderFragment.newInstance(2);
            case 3: return PlaceholderFragment.newInstance(3);
            case 4: return PlaceholderFragment.newInstance(1);
            default: return null;
        }

    }

    @Override
    public int getCount() {
        return 5;
    }
}

VerticalViewPager:

public class VerticalViewPager extends ViewPager {
    public VerticalViewPager(Context context) {
        super(context);
        init();
    }

    public VerticalViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    private void init() {
        setPageTransformer(true, new VerticalPageTransformer());
        setOverScrollMode(OVER_SCROLL_NEVER);
    }

    private class VerticalPageTransformer implements ViewPager.PageTransformer {

        @Override
        public void transformPage(@NonNull View view, float position) {

            if (position < -1) {
                view.setAlpha(0);
            } else if (position <= 1) {
                view.setAlpha(1);

                view.setTranslationX(view.getWidth() * -position);

                float yPosition = position * view.getHeight();
                view.setTranslationY(yPosition);
            } else {
                view.setAlpha(0);
            }
        }
    }

    private MotionEvent swapXY(MotionEvent ev) {
        float width = getWidth();
        float height = getHeight();

        float newX = (ev.getY() / height) * width;
        float newY = (ev.getX() / width) * height;

        ev.setLocation(newX, newY);

        return ev;
    }

    @Override
    public boolean onInterceptTouchEvent(MotionEvent ev) {
        boolean intercepted = super.onInterceptTouchEvent(swapXY(ev));
        swapXY(ev);
        return intercepted;
    }

    @Override
    public boolean onTouchEvent(MotionEvent ev) {
        return super.onTouchEvent(swapXY(ev));
    }

}

0 个答案:

没有答案