Android RecyclerView實現下拉刷新和上拉加載更多
使用官方的刷新控件SwipeRefreshLayout來實現下拉刷新,當RecyclerView滑到底部實現下拉加載(進度條效果用RecyclerView加載一個布局實現)
需要完成控件的下拉監(jiān)聽和上拉監(jiān)聽,其中,下拉監(jiān)聽通過SwipRefreshLayout的setOnRefreshListener()方法監(jiān)聽,而上拉刷新,需要通過監(jiān)聽列表的滾動,當列表滾動到底部時觸發(fā)事件,具體代碼如下
主布局
<?xml version="1.0" encoding="utf-8"?> <android.support.v4.widget.SwipeRefreshLayout android:id="@+id/refresh_layout" xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <android.support.v7.widget.RecyclerView android:id="@+id/recycler_list" android:layout_width="match_parent" android:layout_height="match_parent"/> </android.support.v4.widget.SwipeRefreshLayout>
public class MainActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener { private SwipeRefreshLayout refreshLayout; private RecyclerView recyclerView; private LinearLayoutManager layoutManager; private RecyclerAdapter mAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initViews(); } private void initViews() { refreshLayout = (SwipeRefreshLayout) findViewById(R.id.refresh_layout); recyclerView = (RecyclerView) findViewById(R.id.recycler_list); layoutManager = new LinearLayoutManager(this); refreshLayout.setColorSchemeResources(R.color.colorAccent, R.color.colorPrimary);//設置刷新時進度條 顏色,最多四種 refreshLayout.setOnRefreshListener(this); mAdapter = new RecyclerAdapter();//自定義的適配器 recyclerView.setAdapter(mAdapter); recyclerView.setLayoutManager(layoutManager); recyclerView.addOnScrollListener(new OnRecyclerScrollListener()); } /** * 用于下拉刷新 */ @Override public void onRefresh() { } /** * 用于上拉加載更多 */ public class OnRecyclerScrollListener extends RecyclerView.OnScrollListener { int lastVisibleItem = 0; @Override public void onScrollStateChanged(RecyclerView recyclerView, int newState) { super.onScrollStateChanged(recyclerView, newState); if (mAdapter != null && newState == RecyclerView.SCROLL_STATE_IDLE && lastVisibleItem + 1 == mAdapter.getItemCount()) { //滾動到底部了,可以進行數據加載等操作 } } @Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); lastVisibleItem = layoutManager.findLastVisibleItemPosition(); } } }
下面是實現上拉時進度條轉動的效果
item_list_footer.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/tv_item_footer_load_more" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_margin="16dp" android:gravity="center" android:text="上拉加載更多" /> <ProgressBar android:id="@+id/pb_item_footer_loading" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_margin="16dp" android:visibility="gone"/> </RelativeLayout>
適配器
public class RecyclerAdapter extends RecyclerView.Adapter<ViewHolder> { private static final int TYPE_CONTENT = 0; private static final int TYPE_FOOTER = 1; private ArrayList<DataBean> dataList; private ProgressBar pbLoading; private TextView tvLoadMore; public RecyclerAdapter() { dataList = new ArrayList<>(); } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { if (viewType == TYPE_CONTENT) { return new ContentViewHolder(LayoutInflater.from(parent.getContext()).inflate (R.layout.item_list_content, parent, false)); } else if (viewType == TYPE_FOOTER) {//加載進度條的布局 return new FooterViewHolder(LayoutInflater.from(parent.getContext()).inflate (R.layout.item_list_footer, parent, false)); } return null; } @Override public void onBindViewHolder(ViewHolder holder, int position) { int type = getItemViewType(position); if (type == TYPE_CONTENT) { DataBean bean = dataList.get(position); ((ContentViewHolder) holder).tvId.setText("" + bean.getId()); ((ContentViewHolder) holder).tvName.setText(bean.getName()); } else if (type == TYPE_FOOTER) { pbLoading = ((FooterViewHolder) holder).pbLoading; tvLoadMore = ((FooterViewHolder) holder).tvLoadMore; } } /** * 獲取數據集加上一個footer的數量 */ @Override public int getItemCount() { return dataList.size() + 1; } @Override public int getItemViewType(int position) { if (position + 1 == getItemCount()) { return TYPE_FOOTER; } else { return TYPE_CONTENT; } } /** * 獲取數據集的大小 */ public int getListSize() { return dataList.size(); } /** * 內容的ViewHolder */ public static class ContentViewHolder extends ViewHolder { private TextView tvId, tvName; public ContentViewHolder(View itemView) { super(itemView); tvId = (TextView) itemView.findViewById(R.id.tv_item_id); tvName = (TextView) itemView.findViewById(R.id.tv_item_name); } } /** * footer的ViewHolder */ public static class FooterViewHolder extends ViewHolder { private TextView tvLoadMore; private ProgressBar pbLoading; public FooterViewHolder(View itemView) { super(itemView); tvLoadMore = (TextView) itemView.findViewById(R.id.tv_item_footer_load_more); pbLoading = (ProgressBar) itemView.findViewById(R.id.pb_item_footer_loading); } } /** * 顯示正在加載的進度條,滑動到底部時,調用該方法,上拉就顯示進度條,隱藏"上拉加載更多" */ public void showLoading() { if (pbLoading != null && tvLoadMore != null) { pbLoading.setVisibility(View.VISIBLE); tvLoadMore.setVisibility(View.GONE); } } /** * 顯示上拉加載的文字,當數據加載完畢,調用該方法,隱藏進度條,顯示“上拉加載更多” */ public void showLoadMore() { if (pbLoading != null && tvLoadMore != null) { pbLoading.setVisibility(View.GONE); tvLoadMore.setVisibility(View.VISIBLE); } } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Android實現上拉加載更多以及下拉刷新功能(ListView)
- Android RecyclerView 上拉加載更多及下拉刷新功能的實現方法
- Android ListView實現上拉加載更多和下拉刷新功能
- Android下拉刷新上拉加載更多左滑動刪除
- Android XListView下拉刷新和上拉加載更多
- Android RecyclerView下拉刷新和上拉加載更多
- Android 仿硅谷新聞下拉刷新/上拉加載更多
- Android中Listview下拉刷新和上拉加載更多的多種實現方案
- android使用PullToRefresh框架實現ListView下拉刷新上拉加載更多
- Android實踐之帶加載效果的下拉刷新上拉加載更多
相關文章
詳解android studio游戲搖桿開發(fā)教程,仿王者榮耀搖桿
這篇文章主要介紹了android studio游戲搖桿開發(fā)教程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-05-05Android中創(chuàng)建類似Instagram的漸變背景效果
這篇文章主要介紹了Android中創(chuàng)建類似Instagram的漸變背景效果,本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2017-12-12android設備不識別awk命令 缺少busybox怎么辦
這篇文章主要為大家詳細介紹了android設備不識別awk命令,缺少busybox的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04Android學習筆記之AndroidManifest.xml文件解析(詳解)
這篇文章主要介紹了Android學習筆記之AndroidManifest.xml文件解析,需要的朋友可以參考下2015-10-10深入解析Android App的LayoutInflate布局
這篇文章主要介紹了Android App的LayoutInflate布局,對LayoutInflate編寫中經常被無解及產生錯誤的地方進行了深入說明,需要的朋友可以參考下2016-04-04