ViewPager2如何控制切换动画,实现临近的执行切换动画

该博客介绍了如何在ViewPager2中控制页面切换时的动画效果。通过ViewPager2Utils工具类的isAnimation方法,判断当前页面与目标页面之间的差距,决定是否执行滑动翻页动画,从而实现自定义的页面切换行为。
摘要由CSDN通过智能技术生成

工具类

import java.math.BigDecimal;

public class ViewPager2Utils {
    private volatile static ViewPager2Utils instance = null;

    private ViewPager2Utils() {
    }

    public static ViewPager2Utils getInstance() {
        if (instance == null) {
            synchronized (ViewPager2Utils.class) {
                if (instance == null) {
                    instance = new ViewPager2Utils();
                }
            }
        }
        return instance;
    }

    /**
     * viewPager是否执行动画
     * @param currentItem 当前页面
     * @param item 切换的页面
     * @return false不执行动画,true执行动画
     */
    public boolean isAnimation(int currentItem,int item) {
        BigDecimal currentValue = new BigDecimal(currentItem);
        BigDecimal itemValue = new BigDecimal(item);
        BigDecimal subtract = currentValue.subtract(itemValue);
        if (subtract.abs().intValue() != 1) {
            //去除页面切换时的滑动翻页效果
           return false;
        } else {
            return true;
        }
    }
}

使用

binding.viewPager2.setCurrentItem(position, ViewPager2Utils.getInstance().isAnimation(binding.viewPager2.getCurrentItem(), position));

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值