使用反射机制修改viewPager切换滑动速度

本文介绍如何通过自定义Scroller类并利用反射机制来修改ViewPager的滑动速度,同时提供了解决PagerAdapter在自动切换页面时动画显示问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ViewPager的惯性效果(滑到一定距离自动平滑到另一个pager,或者调用setCurrentItem)是通过scroller来实现的, 其中有个变量为mScroller,为了修改这个滑动的速度,需要改变mScroller的一些值,但是mScroller是私有变量,所以在不直接修改ViewPager源码的情况下,只能用反射修改mScroller。

自定义一个Scroller

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
public class FixedSpeedScroller extends Scroller {
    private int mDuration = 1500;
                                                                                                            
    public FixedSpeedScroller(Context context) {
        super(context);
    }
                                                                                                            
    public FixedSpeedScroller(Context context, Interpolator interpolator) {
        super(context, interpolator);
    }
                                                                                                            
    @Override
    public void startScroll(int startX, int startY, int dx, int dy, int duration) {
        // Ignore received duration, use fixed one instead
        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 setmDuration(int time) {
        mDuration = time;
    }
                                                                                                            
    public int getmDuration() {
        return mDuration;
    }
}


使用方法:

1
2
3
4
5
6
7
8
9
10
try {
                Field field = ViewPager.class.getDeclaredField("mScroller");
                field.setAccessible(true);
                FixedSpeedScroller scroller = new FixedSpeedScroller(mViewPager.getContext(),
                        new AccelerateInterpolator());
                field.set(mViewPager, scroller);
                scroller.setmDuration(2000);
            } catch (Exception e) {
                LogUtils.e(TAG, "", e);
            }

注意点:
PagerAdapter 的destroyItem 每次会删除上一个页面,导致,如果做自动切换页面时会看不到动画.

解决办法:
destoryItem中不做删除view,instantiateItem中对view是否有parent做为判断条件,这种情况适用于,少量的固定的子View,比如一个Banner,banner中做自动循环播放

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值