android viewpager滑动视差动画(parallax)

本文详细解析如何使用ViewPager.setPageTransformer方法在滑动控件中实现Parallax效果,包括核心代码分析和日志解读,以及Parallax效果在不同位置(-1到1)的表现。

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

就是当滑动时,指定一个你想让他不随整体滑动或步调一致的滑动控件,那么就可以通过viewPager.setPageTransformer(false, pt)的这个方法来设置,其中pt是继承ViewPager.PageTransformer的类对象,核心代码如下:MainActivity
        ParallaxPagerTransformer pt = new ParallaxPagerTransformer((R.id.image));
        //pt.setBorder(20);
        //pt.setSpeed(0.2f);
        mPager.setPageTransformer(false, pt);

ParallaxPagerTransformer

public class ParallaxPagerTransformer implements ViewPager.PageTransformer {

    private int id;
    private int border = 0;
    private float speed = 0.2f;

    public ParallaxPagerTransformer(int id) {
        this.id = id;
    }

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

        View parallaxView = view.findViewById(id);
Log.i("ParallaxPagerTransformer", "transformPage    "+position);
        if (parallaxView != null) {
            if (position > -1 && position < 1) {
            	Log.i("ParallaxPagerTransformer", "position    "+position);
                float width = parallaxView.getWidth();
                parallaxView.setTranslationX(-(position * width * speed));
                float sc = ((float)view.getWidth() - border)/ view.getWidth();
                if (position == 0) {
                    view.setScaleX(1);
                    view.setScaleY(1);
                } else {
                    view.setScaleX(sc);
                    view.setScaleY(sc);
                }
            }
        }
    }

    public void setBorder(int px) {
        border = px;
    }

    public void setSpeed(float speed) {
        this.speed = speed;
    }


}

这段代码我打了日志,分析了下:viewpager分为左中右三块(-1 0 1);初始的时候,左边没有pager,当向左滑的时候,此时的pager的position取值范围【-1,0】,右边来的pager的position取值范围【0,1】,那么此时想让里面的imageview移动的慢点,就要设置parallaxView.setTranslationX(-(position * width * speed));

git:https://github.com/linghp/my_parallax

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值