android 卡片投影渐变,受Duolingo启发的ViewPager卡片效果

如果你曾经使用过Duolingo,你很可能注意过这个部件:

1472147923106017.gif

看着很酷是吧?我对Duolingo团队是如何做到这个样子的很感兴趣,于是自己搭建了个项目来实现这种效果。

这与普通ViewPager的主要区别在于,你可以同时看到3个item,其中两个只能看到部分。

我做的第一件事就是创建拥有一个CardView的简单布局:

1472147934915673.png

当adapter完成之后,在activity里设置好ViewPager:

xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:fitsSystemWindows="true">

android:id="@+id/viewPager"

android:layout_width="match_parent"

android:layout_height="330dp"

android:layout_gravity="bottom"

android:clipToPadding="false"

android:overScrollMode="never"

android:paddingBottom="30dp"

android:paddingEnd="@dimen/card_padding"

android:paddingLeft="@dimen/card_padding"

android:paddingRight="@dimen/card_padding"

android:paddingStart="@dimen/card_padding" />

这里最重要的就是clipToPadding属性。当它为false时,ViewPager并不会剪掉我们想部分显示的View,而当前的item又能在中间。

通过改变card_padding,你能改变view的宽度。在这个例子中,我使用了60dp来得到类似Duolingo的效果。

当设置完这些之后,我们应该已经有了三个可见的item了,一个剧终,另外两个部分可见。现在我们只需要实现卡片的动画立体效果。

阴影动画

为此,我创建了一个实现了OnPageChangeListener 和 PageTransformer 的ShadowTransformer。当用户滑动到下一张卡片的时候,它应该变高,而前一张卡片则变低。

这是通过CardView的setCardElevation方法,根据scroll offset产生的恰当因素而实现的。在本例中,CardView的基准高度是默认的(2dp),而卡片可以上升到16dp。

最终效果:

1472147946607221.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值