这两天在GitHub上传了一个自定义ViewPager:CoolViewPager,具有以下功能特征:

支持水平及垂直方向循环滚动支持自动滚动支持自动滚动方向、滚动时间、间隔时间的设置支持调用notifyDataSetChanged实时刷新界面支持边缘效果颜色的设置为垂直滚动提供了适宜的界面切换效果

为什么写这个库

我们平时使用support包中的ViewPager,当adapter中数据变更后,调用notifyDataSetChanged并不能刷新界面,需要重新调用ViewPager.setAdapter方法;网上所有的自定义ViewPager,几乎都没有提供垂直方向的切换效果;很多时候,我们需要变更ViewPager滑动到边缘的渐变色以配合App特定场景.CoolViewPager可以很方便的解决上述问题.

使用步骤

在你的build.gradle中添加依赖

dependencies { implementation 'com.huanhailiuxin.view:coolviewpager:1.0.0'}

在你的布局文件中引入CoolViewPager

<com.huanhailiuxin.coolviewpager.CoolViewPager android:id="@+id/vp" android:layout_width="match_parent" android:layout_height="match_parent" />

在Java代码中获取CoolViewPager,设置各种属性,为其设置Adapter

public class ActivityEdgeEffectColor extends BaseActivity { private CoolViewPager vp; **** CoolViewPager vp = findViewById(R.id.vp); vp.setScrollMode(CoolViewPager.ScrollMode.HORIZONTAL); vp.setAdapter(adapter); ****}属性:

<?xml version="1.0" encoding="utf-8"?><resources> <declare-styleable name="CoolViewPager"> <attr name="cvp_scrollmode" format="enum"> <enum name="horizontal" value="0" /> <enum name="vertical" value="1" /> </attr> <attr name="cvp_autoscroll" format="boolean" /> <attr name="cvp_intervalinmillis" format="integer"/> <attr name="cvp_autoscrolldirection" format="enum"> <enum name="forward" value="0" /> <enum name="backward" value="1" /> </attr> <attr name="cvp_infiniteloop" format="boolean" /> <attr name="cvp_scrollduration" format="integer"/> <attr name="cvp_drawedgeeffect" format="boolean"/> <attr name="cvp_edgeeffectcolor" format="color"/> </declare-styleable></resources>

我们可以通过xml或Java代码的方式设置CoolViewPager实例的属性.

attribute namedescriptioncvp_scrollmode滚动方向cvp_autoscroll是否开启自动滚动cvp_intervalinmillis自动滚动时间间隔cvp_autoscrolldirection自动滚动方向cvp_infiniteloop是否循环滚动cvp_scrollduration自动滚动耗时cvp_drawedgeeffect是否绘制边缘效果cvp_edgeeffectcolor绘制的边缘效果颜色通过XML布局文件

<com.huanhailiuxin.coolviewpager.CoolViewPager android:id="@+id/vp" android:layout_width="match_parent" android:layout_height="match_parent" app:cvp_scrollmode="vertical" app:cvp_autoscroll="true" app:cvp_intervalinmillis="1000" app:cvp_autoscrolldirection="backward" app:cvp_infiniteloop="true" app:cvp_scrollduration="600" app:cvp_drawedgeeffect="true" app:cvp_edgeeffectcolor="@color/colorPrimary" />通过Java代码

public class ActivityEdgeEffectColor extends BaseActivity { private CoolViewPager vp; private void initViewPager(){ vp = findViewById(R.id.vp); vp.setScrollMode(CoolViewPager.ScrollMode.VERTICAL); vp.setAutoScroll(true,1000); vp.setAutoScrollDirection(CoolViewPager.AutoScrollDirection.BACKWARD); vp.setInfiniteLoop(true); vp.setScrollDuration(true,600); vp.setDrawEdgeEffect(true); vp.setEdgeEffectColor(getResources().getColor(R.color.colorPrimary)); }}