把 ViewPager 撸成栈

最近有看到一些栈式列表的效果,突然发现ViewPager也能做到较为简易的效果,实在是迫不及待。

效果图

这还是你熟悉的ViewPager么?

stack

源码

https://github.com/fashare2015/StackPageTransformer

使用

很简单就一个类 —— StackPageTransformer.

没有打成jar包,使用时直接复制源码即可:StackPageTransformer

// 默认配置
mViewPager.setPageTransformer(true, new StackPageTransformer(mViewPager));

// 或
mViewPager.setPageTransformer(true, new StackPageTransformer(mViewPager, 0.8f, 0.9f, 5));
0.8f -> // 栈底: 最小页面缩放比
0.9f -> // 栈顶: 最大页面缩放比
5    -> // 栈内页面数

实现

主要依赖ViewPager.PageTransformer.transformPage(View view, float position).

其中的position落在0~mStackCount-1时,进行相应的位移,从而堆成栈的效果.

还有一些渐变过渡的处理比较繁琐,有兴趣的话自行看代码吧.

灵感来源

官方教程 —— Depth Page Transformer

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值