使用官方的刷新控件SwipeRefreshLayout来实现下拉刷新,当RecyclerView滑到底部实现下拉加载(进度条效果用RecyclerView加载一个布局实现)

需要完成控件的下拉监听和上拉监听,其中,下拉监听通过SwipRefreshLayout的setOnRefreshListener()方法监听,而上拉刷新,需要通过监听列表的滚动,当列表滚动到底部时触发事件,具体代码如下
主布局
<?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);
}
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# RecyclerView
# 下拉刷新
# 上拉加载
# Android实现上拉加载更多以及下拉刷新功能(ListView)
# Android RecyclerView 上拉加载更多及下拉刷新功能的实现方法
# Android ListView实现上拉加载更多和下拉刷新功能
# Android下拉刷新上拉加载更多左滑动删除
# Android XListView下拉刷新和上拉加载更多
# Android RecyclerView下拉刷新和上拉加载更多
# Android 仿硅谷新闻下拉刷新/上拉加载更多
# Android中Listview下拉刷新和上拉加载更多的多种实现方案
# android使用PullToRefresh框架实现ListView下拉刷新上拉加载更多
# Android实践之带加载效果的下拉刷新上拉加载更多
# 加载
# 进度条
# 最多
# 自定义
# 四种
# 而上
# 来实现
# 正在加载
# 大家多多
# 滑到
# mAdapter
# layoutManager
# RecyclerAdapter
# Override
# onCreate
# void
# protected
# LinearLayoutManager
# AppCompatActivity
# implements
相关文章:
实例解析angularjs的filter过滤器
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
英语简历制作免费网站推荐,如何将简历翻译成英文?
如何在阿里云部署织梦网站?
如何通过西部数码建站助手快速创建专业网站?
常州企业建站如何选择最佳模板?
一键网站制作软件,义乌购一件代发流程?
宝塔新建站点为何无法访问?如何排查?
已有域名如何免费搭建网站?
上海制作企业网站有哪些,上海有哪些网站可以让企业免费发布招聘信息?
建站主机数据库如何配置才能提升网站性能?
如何选择适合PHP云建站的开源框架?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
jQuery 常见小例汇总
如何在VPS电脑上快速搭建网站?
已有域名建站全流程解析:网站搭建步骤与建站工具选择
如何用已有域名快速搭建网站?
如何基于云服务器快速搭建个人网站?
高防服务器租用首荐平台,企业级优惠套餐快速部署
昆明网站制作哪家好,昆明公租房申请网上登录入口?
临沂网站制作公司有哪些,临沂第四中学官网?
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
导航网站建站方案与优化指南:一站式高效搭建技巧解析
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?
相册网站制作软件,图片上的网址怎么复制?
建站之星如何防范黑客攻击与数据泄露?
如何选择可靠的免备案建站服务器?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
建站之星如何一键生成手机站?
如何注册花生壳免费域名并搭建个人网站?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?
如何选择高效稳定的ISP建站解决方案?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
代刷网站制作软件,别人代刷火车票靠谱吗?
已有域名能否直接搭建网站?
建站上传速度慢?如何优化加速网站加载效率?
制作网站的软件免费下载,免费制作app哪个平台好?
如何确保西部建站助手FTP传输的安全性?
企业微网站怎么做,公司网站和公众号有什么区别?
建站之星IIS配置教程:代码生成技巧与站点搭建指南
油猴 教程,油猴搜脚本为什么会网页无法显示?
如何制作网站标识牌,动态网站如何制作(教程)?
建站之星如何快速生成多端适配网站?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
上海网站制作网站建设公司,建筑电工证网上查询系统入口?
北京建设网站制作公司,北京古代建筑博物馆预约官网?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
*请认真填写需求信息,我们会在24小时内与您取得联系。