首先看效果,框架中幫我們實(shí)現(xiàn)了幾個(gè)主流的刷新效果,Twitter style,JD style,google style,Yalantis style,demo也下載下來(lái)看了,真不錯(cuò),還支持各種自定義,自定義頭部和尾部,頭部還分classic,above,blow,scale四種類(lèi)型,還有自動(dòng)刷新的效果,體驗(yàn)也很流暢。
再看代碼,刷新,加載各一個(gè)接口實(shí)現(xiàn),頭部和尾部也都是用接口實(shí)現(xiàn),遵循設(shè)計(jì)模式的依賴(lài)倒轉(zhuǎn)原則原則(針對(duì)抽象而不是針對(duì)具體編程),所以才能具備那么高可塑性,我們要做的就是實(shí)現(xiàn)接口里面的內(nèi)容就可以輕松寫(xiě)一個(gè)刷新效果,就像使用baseAdapter一樣,無(wú)論什么數(shù)據(jù),什么樣式,都可以輕松實(shí)現(xiàn)。
接著看功能,支持各種View和ViewGroup(ListView,ScrollView,RecyclerView,GridView,WebView,Linearlayout,RelativeLayout,F(xiàn)rameLayout,ImageView,TextView等)的刷新和加載,還支持自動(dòng)刷新,手動(dòng)刷新,自動(dòng)加載,手動(dòng)加載,禁止刷新,禁止加載等操作,完全滿(mǎn)足需求。
最后,說(shuō)的這么好,有沒(méi)有經(jīng)過(guò)測(cè)試呢?當(dāng)然了,口說(shuō)無(wú)憑,帶大家實(shí)現(xiàn)一個(gè)。
通過(guò)SwipeToLoadLayout實(shí)現(xiàn)一個(gè)刷新加載的效果
1、如何集成
Step 1. Add the JitPack repository in your build.gradle at the end of repositories:
repositories { maven { url "https://jitpack.io" }}Step 2. Add the dependency in the form
dependencies { compile 'com.github.aspsine:SwipeToLoadLayout:v1.0.0'}2,開(kāi)始自定義刷新效果
swipeToLoadLayout提供了一套接口,刷新的頭部自定義一個(gè)View實(shí)現(xiàn)SwipeTrigger和SwipeRefreshTrigger就行了,刷新的尾部自定義一個(gè)View實(shí)現(xiàn)SwipeLoadMoreTrigger和SwipeTrigger,頭部實(shí)現(xiàn)代碼:
public class CustomRefreshHeadView extends TextView implements SwipeRefreshTrigger, SwipeTrigger { public CustomRefreshHeadView(Context context) { super(context); } public CustomRefreshHeadView(Context context, AttributeSet attrs) { super(context, attrs); } public CustomRefreshHeadView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); } @Override public void onRefresh() { setText("正在拼命加載數(shù)據(jù)..."); } @Override public void onPRepare() { } @Override public void onSwipe(int i, boolean b) { setText("釋放刷新"); } @Override public void onRelease() { } @Override public void complete() { setText("刷新成功"); } @Override public void onReset() { }}xml中使用
注意,swipetoloadlayout中布局包裹的View id是指定的,不能亂改,否則找不到<item name="swipe_target" type="id" />刷新目標(biāo)<item name="swipe_refresh_header" type="id" />刷新頭部<item name="swipe_load_more_footer" type="id" />刷新尾部
<?xml version="1.0" encoding="utf-8"?><com.aspsine.swipetoloadlayout.SwipeToLoadLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/swipeToLoad" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.yyydjk.swipetorefreshdemo.MainActivity"> <com.yyydjk.swipetorefreshdemo.CustomRefreshHeadView android:id="@+id/swipe_refresh_header" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:padding="20dp" /> <TextView android:id="@+id/swipe_target" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/colorPrimary" android:gravity="center" android:text="Hello World!" /></com.aspsine.swipetoloadlayout.SwipeToLoadLayout>代碼中調(diào)用
CustomRefreshHeadView refreshHeadView = new CustomRefreshHeadView(this);refreshHeadView.setPadding(20,20,20,20);refreshHeadView.setGravity(Gravity.CENTER);refreshHeadView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));swipeToLoadLayout.setRefreshHeaderView(refreshHeadView);就這么簡(jiǎn)單,看下演示效果,做的丑了點(diǎn),以后有時(shí)間弄個(gè)精致點(diǎn)的
swipeToRefresh.gif
轉(zhuǎn)自:http://www.jianshu.com/p/d69ae409a52c
好吧,讓我們?cè)賮?lái)看個(gè)栗子:
Step 1. Create an Simple RefreshHeaderView
public class RefreshHeaderView extends TextView implements SwipeRefreshTrigger, SwipeTrigger { public RefreshHeaderView(Context context) { super(context); } public RefreshHeaderView(Context context, AttributeSet attrs) { super(context, attrs); } @Override public void onRefresh() { setText("REFRESHING"); } @Override public void onPrepare() { setText(""); } @Override public void onMove(int yScrolled, boolean isComplete, boolean automatic) { if (!isComplete) { if (yScrolled >= getHeight()) { setText("RELEASE TO REFRESH"); } else { setText("SWIPE TO REFRESH"); } } else { setText("REFRESH RETURNING"); } } @Override public void onRelease() { } @Override public void onComplete() { setText("COMPLETE"); } @Override public void onReset() { setText(""); }}Step 2. Create an Simple LoadMoreFooterView
public class LoadMoreFooterView extends TextView implements SwipeTrigger, SwipeLoadMoreTrigger { public LoadMoreFooterView(Context context) { super(context); } public LoadMoreFooterView(Context context, AttributeSet attrs) { super(context, attrs); } @Override public void onLoadMore() { setText("LOADING MORE"); } @Override public void onPrepare() { setText(""); } @Override public void onMove(int yScrolled, boolean isComplete, boolean automatic) { if (!isComplete) { if (yScrolled <= -getHeight()) { setText("RELEASE TO LOAD MORE"); } else { setText("SWIPE TO LOAD MORE"); } } else { setText("LOAD MORE RETURNING"); } } @Override public void onRelease() { setText("LOADING MORE"); } @Override public void onComplete() { setText("COMPLETE"); } @Override public void onReset() { setText(""); }}Step 3. Edit activity layout xml
<?xml version="1.0" encoding="utf-8"?><com.aspsine.swipetoloadlayout.SwipeToLoadLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/swipeToLoadLayout" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.aspsine.swipetoloadlayoutdemo.MainActivity"> <com.aspsine.swipetoloadlayoutdemo.RefreshHeaderView android:id="@id/swipe_refresh_header" android:layout_width="match_parent" android:gravity="center" android:layout_height="100dp" /> <ListView android:id="@id/swipe_target" android:layout_width="match_parent" android:layout_height="match_parent" /> <com.aspsine.swipetoloadlayoutdemo.LoadMoreFooterView android:id="@id/swipe_load_more_footer" android:layout_width="match_parent" android:gravity="center" android:layout_height="100dp" /></com.aspsine.swipetoloadlayout.SwipeToLoadLayout>Note:
refresh header viewandroid:id="@id/swipe_refresh_header"target viewandroid:id="@id/swipe_target"load more footer viewandroid:id="@id/swipe_load_more_footer"Step 4. Write java code
public class MainActivity extends AppCompatActivity implements OnRefreshListener, OnLoadMoreListener { SwipeToLoadLayout swipeToLoadLayout; ArrayAdapter<String> mAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); swipeToLoadLayout = (SwipeToLoadLayout) findViewById(R.id.swipeToLoadLayout); ListView listView = (ListView) findViewById(R.id.swipe_target); swipeToLoadLayout.setOnRefreshListener(this); swipeToLoadLayout.setOnLoadMoreListener(this); mAdapter = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_expandable_list_item_1); listView.setAdapter(mAdapter); autoRefresh(); } @Override public void onRefresh() { swipeToLoadLayout.postDelayed(new Runnable() { @Override public void run() { swipeToLoadLayout.setRefreshing(false); mAdapter.add("REFRESH:/n" + new Date()); } }, 2000); } @Override public void onLoadMore() { swipeToLoadLayout.postDelayed(new Runnable() { @Override public void run() { swipeToLoadLayout.setLoadingMore(false); mAdapter.add("LOAD MORE:/n" + new Date()); } }, 2000); } private void autoRefresh() { swipeToLoadLayout.post(new Runnable() { @Override public void run() { swipeToLoadLayout.setRefreshing(true); } }); }}demo地址:https://github.com/Aspsine/SwipeToLoadLayout.git哈哈,這下應(yīng)該沒(méi)問(wèn)題啦!參考文檔:https://github.com/Aspsine/SwipeToLoadLayout/wiki/Quick-Setup
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注