這兩天在GitHub上傳了一個自定義ViewPager:CoolViewPager,具備如下功能特徵:java
- 支持水平及垂直方向循環滾動
- 支持自動滾動
- 支持自動滾動方向、滾動時間、間隔時間的設置
- 支持調用notifyDataSetChanged實時刷新界面
- 支持邊緣效果顏色的設置
- 爲垂直滾動提供了適宜的界面切換效果
爲何寫這個庫
咱們平時使用support包中的ViewPager,當adapter中數據變動後,調用notifyDataSetChanged並不能刷新界面,須要從新調用ViewPager.setAdapter方法;網上全部的自定義ViewPager,幾乎都沒有提供垂直方向的切換效果;不少時候,咱們須要變動ViewPager滑動到邊緣的漸變色以配合App特定場景.CoolViewPager能夠很方便的解決上述問題.android
使用步驟
在你的build.gradle中添加依賴git
dependencies { implementation 'com.huanhailiuxin.view:coolviewpager:1.0.0' }
在你的佈局文件中引入CoolViewPagergithub
<com.huanhailiuxin.coolviewpager.CoolViewPager android:id="@+id/vp" android:layout_width="match_parent" android:layout_height="match_parent" />
在Java代碼中獲取CoolViewPager,設置各類屬性,爲其設置Adapterapp
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實例的屬性.oop
attribute name | description |
---|---|
cvp_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)); } }