Android SwipeRefreshLayout下拉刷新組件示例
SwipeRefreshLayout概述
SwipeRefrshLayout是Google官方更新的一個(gè)Widget,可以實(shí)現(xiàn)下拉刷新的效果。該控件集成自ViewGroup在support-v4兼容包下,不過我們需要升級(jí)supportlibrary的版本到19.1以上。
用戶通過手勢(shì)或者點(diǎn)擊某個(gè)按鈕實(shí)現(xiàn)內(nèi)容視圖的刷新,布局里加入SwipeRefreshLayout嵌套一個(gè)子視圖如ListView、 RecyclerView等,觸發(fā)刷新會(huì)通過OnRefreshListener的onRefresh方法回調(diào),我們?cè)谶@里執(zhí)行頁面數(shù)據(jù)的刷新,每次手勢(shì) 的完成都會(huì)執(zhí)行一次通知,根據(jù)滑動(dòng)距離判斷是否需要回調(diào)。setRefreshing(false)通過代碼直接取消刷新,true則手動(dòng)設(shè)置刷新調(diào)出刷 新視圖。setEnabled(false)通過boolean控制是否禁用手勢(shì)刷新 。
基本使用的方法如下:
1.setOnRefreshListener(OnRefreshListener):添加下拉刷新監(jiān)聽器
2.setRefreshing(boolean):顯示或者隱藏刷新進(jìn)度條
3.isRefreshing():檢查是否處于刷新狀態(tài)
使用非常簡(jiǎn)單,用一個(gè)簡(jiǎn)單案例來介紹SwipeRefreshLayout下拉刷新的功能。
布局文件
<?xml version="1.0" encoding="utf-8"?> <android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/v7_refresh" android:layout_width="match_parent" android:layout_height="match_parent" android:background="@color/back"> <android.support.v7.widget.RecyclerView android:id="@+id/v7_recyclerView" android:layout_width="match_parent" android:layout_height="match_parent" /> </android.support.v4.widget.SwipeRefreshLayout>
item.xml
<?xml version="1.0" encoding="utf-8"?> <android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/cardview" app:cardCornerRadius="5dp" app:cardBackgroundColor="@android:color/white" android:layout_margin="5dp" android:layout_height="60dp" android:layout_width="match_parent"> <TextView android:id="@+id/menuitem_tv" android:layout_gravity="center" android:text="@string/app_name" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </android.support.v7.widget.CardView>
Activity
public class MainActivity extends AppCompatActivity { private SwipeRefreshLayout swipeRefreshLayout; private RecyclerView recyclerView; private List<String> list=null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main_activity); initView(); } private void initView() { swipeRefreshLayout=(SwipeRefreshLayout)findViewById(R.id.v7_refresh); recyclerView=(RecyclerView)findViewById(R.id.v7_recyclerView); //設(shè)置下拉圓圈的大小,兩個(gè)值 LARGE, DEFAULT swipeRefreshLayout.setSize(SwipeRefreshLayout.LARGE); // 設(shè)定下拉圓圈的背景:默認(rèn)white // swipeRefreshLayout.setProgressBackgroundColor(android.R.color.white); initData(); } private void initData() { bindData(); //設(shè)置刷新時(shí)動(dòng)畫的顏色,可以設(shè)置4個(gè) swipeRefreshLayout.setColorSchemeResources(android.R.color.holo_blue_light, android.R.color.holo_red_light, android.R.color.holo_orange_light, android.R.color.holo_green_light); swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { @Override public void onRefresh() { Toast.makeText (MainActivity.this,"正在刷新",Toast.LENGTH_LONG).show(); // TODO Auto-generated method stub new Handler().postDelayed(new Runnable() { @Override public void run() { // TODO Auto-generated method stub Toast.makeText (MainActivity.this,"刷新完成",Toast.LENGTH_LONG).show(); swipeRefreshLayout.setRefreshing(false); } }, 4000); } }); } private void bindData(){ list=new ArrayList<>(); for(int i=0;i<22;i++){ list.add("Item"+(i+1)); } recyclerView.setLayoutManager(new LinearLayoutManager(this)); recyclerView.setHasFixedSize(true); recyclerView.setItemAnimator(new DefaultItemAnimator()); MenuAdapter menuAdapter=new MenuAdapter(this,R.layout.item,list); recyclerView.setAdapter(menuAdapter); menuAdapter.setOnItemClickListener(new CommonRecyclerAdapter.OnItemClickListener() { @Override public void onItemClick(RecyclerView.ViewHolder viewHolder, View view, int position) { Toast.makeText (MainActivity.this, list.get(position),Toast.LENGTH_LONG).show(); } }); } }
運(yùn)行效果如圖:
源碼點(diǎn)擊下載:SwipeRefreshLayout_jb51.rar
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android 使用SwipeRefreshLayout控件仿抖音做的視頻下拉刷新效果
- Android SwipeRefreshLayout仿抖音app靜態(tài)刷新
- android使用SwipeRefreshLayout實(shí)現(xiàn)ListView下拉刷新上拉加載
- android基于SwipeRefreshLayout實(shí)現(xiàn)類QQ的側(cè)滑刪除
- Android SwipereFreshLayout下拉刷新
- Android實(shí)現(xiàn)SwipeRefreshLayout首次進(jìn)入自動(dòng)刷新
- Android SwipeRefreshLayout下拉刷新源碼解析
- Android SwipeRefreshLayout超詳細(xì)講解
相關(guān)文章
使用Android自定義控件實(shí)現(xiàn)滑動(dòng)解鎖九宮格
最近由于Android項(xiàng)目需要,要求做一個(gè)類似于支付寶的九宮格解鎖組件,下面小編給大家分享了具體實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-10-10詳解Android 視頻播放時(shí)停止后臺(tái)運(yùn)行的方法
這篇文章主要介紹了詳解Android 視頻播放時(shí)停止后臺(tái)運(yùn)行的方法的相關(guān)資料,需要的朋友可以參考下2017-06-06Android的OkHttp包處理用戶認(rèn)證的代碼實(shí)例分享
OkHttp包(GitHub主頁github.com/square/okhttp)是一款高人氣安卓HTTP支持包,這里我們來看一下Android的OkHttp包處理用戶認(rèn)證的代碼實(shí)例分享:2016-07-07Flutter中顯示條件Widget的實(shí)現(xiàn)方式
在 Flutter 日常開發(fā)中經(jīng)常會(huì)遇見這樣的需求,如: 只有用戶是 VIP 時(shí),才能展示某個(gè)入口或者某個(gè)模塊,這樣的需求在開發(fā)業(yè)務(wù)需求中多如牛毛,那你是如何來優(yōu)雅的實(shí)現(xiàn)的呢,本文將給大家介紹Flutter中顯示條件Widget的實(shí)現(xiàn)方式,需要的朋友可以參考下2024-04-04Android實(shí)現(xiàn)3D標(biāo)簽云簡(jiǎn)單效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)3D標(biāo)簽云簡(jiǎn)單效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05詳解Android中常見的內(nèi)存優(yōu)化及內(nèi)存泄露場(chǎng)景
本文主要給大家介紹了Android中常見的內(nèi)存優(yōu)化及Android開發(fā)中容易造成內(nèi)存泄露的場(chǎng)景,對(duì)我們的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2023-08-08Android自定義滑動(dòng)刪除效果的實(shí)現(xiàn)代碼
這篇文章將從現(xiàn)有 Android 滑動(dòng)刪除的痛點(diǎn),到搭建好一個(gè)基本的框架,到最終提供一份完整的 Demo為止,爭(zhēng)取為讀者提供最大的可定制化,需要的朋友可以參考下2018-03-03android 關(guān)于webview 加載h5網(wǎng)頁開啟定位的方法
今天小編就為大家分享一篇android 關(guān)于webview 加載h5網(wǎng)頁開啟定位的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-07-07Android UI設(shè)計(jì)系列之自定義Dialog實(shí)現(xiàn)各種風(fēng)格的對(duì)話框效果(7)
這篇文章主要介紹了Android UI設(shè)計(jì)系列之自定義Dialog實(shí)現(xiàn)各種風(fēng)格的對(duì)話框效果,具有一定的實(shí)用性和參考價(jià)值,感興趣的小伙伴們可以參考一下2016-06-06