简体   繁体   English

android - 如何为viewPager设置动画

[英]android -How to animate viewPager

This is my code for making ViewPager .I want to animate between changing the pages . 这是我制作ViewPager代码。我想在更改页面之间进行动画处理。 so I write this code : 所以我写这段代码:

ViewPagerAdapter adapter;
                adapter = new ViewPagerAdapter(FistActiivty.this,imges);
                vp.setAdapter(adapter);
                pageSwitcher(2);

try {
                    Field mScroller;
                    mScroller = ViewPager.class.getDeclaredField("mScroller");
                    mScroller.setAccessible(true); 
                    Interpolator sInterpolator = new AccelerateInterpolator();
                    FixedSpeedScroller scroller = new FixedSpeedScroller(vp.getContext(), sInterpolator);
                    // scroller.setFixedDuration(5000);
                    mScroller.set(vp, scroller);
                } catch (Exception e) {
                    Log.v("this",e.getMessage());
                }

public class FixedSpeedScroller extends Scroller {

        private int mDuration = 2000;

        public FixedSpeedScroller(Context context) {
            super(context);
        }

        public FixedSpeedScroller(Context context, Interpolator interpolator) {
            super(context, interpolator);
        }

        public FixedSpeedScroller(Context context, Interpolator interpolator, boolean flywheel) {
            super(context, interpolator, flywheel);
        }

        @Override
        public void startScroll(int startX, int startY, int dx, int dy, int duration) {
            super.startScroll(startX, startY, dx, dy, mDuration);
        }

        @Override
        public void startScroll(int startX, int startY, int dx, int dy) {
            // Ignore received duration, use fixed one instead
            super.startScroll(startX, startY, dx, dy, mDuration);
        }
    }

    public void pageSwitcher(int seconds) {
        timer = new Timer(); // At this line a new Thread will be created
        timer.scheduleAtFixedRate(new RemindTask(), 0, seconds * 1000);

    }
    class RemindTask extends TimerTask {
        @Override
        public void run() {
            runOnUiThread(new Runnable() {
                public void run() {
                    Log.v("this","change pager " +page);
                    if (page > imges.length) { 
                        vp.setCurrentItem(0);
                        page=1;
                    } else {
                        vp.setCurrentItem(page++);
                    }
                }
            });

        }
    }


    class ViewPagerAdapter extends PagerAdapter {
        Context context;
        String[] img;
        LayoutInflater inflater;
        ImageLoader imageLoader = ImageLoader.getInstance();
        DisplayImageOptions options;
        private ImageLoadingListener imageListener;

        public ViewPagerAdapter(Context context, String[] img) {
            this.context = FistActiivty.this;
            this.img = img;
        }

        @Override
        public int getCount() {
            return img.length;
        }


        @Override
        public boolean isViewFromObject(View view, Object object) {
            return view == ((RelativeLayout) object);
        }

        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            ImageView imgflag;
            inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            View itemView = inflater.inflate(R.layout.viewpager_item, container,false);
            imgflag = (ImageView) itemView.findViewById(R.id.flag);
            imageLoader.displayImage(img[position], imgflag,options, imageListener);
            ((ViewPager) container).addView(itemView);

            return itemView;
        }

        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            // Remove viewpager_item.xml from ViewPager
            ((ViewPager) container).removeView((RelativeLayout) object);

        }

    }

The result of this code is this . 这段代码的结果是这样的。 It change the viewpager every 2 seconds and it works fine but it doesn't animate between changing the pages but when I manually change the pager , it animates it . 它每隔2秒更改一次viewpager并且工作正常,但在更改页面之间没有动画,但是当我手动更改寻呼机时,它会为其设置动画。

How can I force it to animate when it want to change the pages ? 如果要更改页面,如何强制它进行动画处理?

Thanks. 谢谢。

Try using the smoothscroll option if that's what you mean. 如果这就是你的意思,尝试使用smoothscroll选项。
Change to this inside your TimerTask. 在TimerTask中更改为此内容。

if (page > imges.length) { 
   vp.setCurrentItem(0, true);
   page=1;
} else {
   vp.setCurrentItem(page++, true);
}

I Think you should use PageTransformer to apply animations on page change.. 我认为您应该使用PageTransformer在页面更改时应用动画。

Please visit this link... 请访问链接...

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM