效果图:

首先要添加依赖:

//xrecyclerview
implementation 'com.jcodecraeer:xrecyclerview:1.3.2'
//Gson
implementation 'com.google.code.gson:gson:2.2.4'
//okhttputils
implementation 'com.zhy:okhttputils:2.0.0' 权限:
<uses-permission android:name="android.permission.INTERNET" />

布局:
    <com.jcodecraeer.xrecyclerview.XRecyclerView
android:id="@+id/RV_all"
android:layout_width="match_parent"
android:layout_height="match_parent"> </com.jcodecraeer.xrecyclerview.XRecyclerView>

All_Fragment:
public class All_Fragment extends Fragment {

    private XRecyclerView RV_all;//XRecyclerView
private int i=0;//页数
private Adapter_All adapter_all;//适配器
private ArrayList<Bean_All.MessageBean.AnchorsBean> data;//把获取的数据放到集合里
private int con=0;//判断con是否等于0等于0就执行适配器和瀑布流con不等于0就刷新界面 @Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View inflate = inflater.inflate(R.layout.fragment_all_, container, false);
initView(inflate);
data = new ArrayList<>();
//okhttp解析
okhttp(i);
return inflate;
}
private void okhttp(final int i) {
OkHttpUtils.get()
.url(Cans.HOME_PAGE + "" + i + "&index=0")//地址
.build().execute(new StringCallback() {
@Override
public void onError(Request request, Exception e) {
Log.e("Song-All-onError", request + "");
}
@Override
public void onResponse(String response) {
Log.e("Song-All-onResponse", response + "");
//解析所有数据
all(response);
}
});
}
//解析所有数据
private void all(String response) {
//Gson解析
Gson gson = new Gson();
//获取Bean类的数据
Bean_All bean_all = gson.fromJson(response, Bean_All.class);
final List<Bean_All.MessageBean.AnchorsBean> anchors = bean_all.getMessage().getAnchors();
//把Bean类获取的数据放到集合中
data.addAll(anchors);
//判断con是否等于0等于0就执行适配器和瀑布流con不等于0就刷新界面
if (con == 0){
//瀑布流
RV_all.setLayoutManager(new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL));
//适配器
adapter_all = new Adapter_All(data, getActivity());
//添加适配器
RV_all.setAdapter(adapter_all);
}else {
adapter_all.notifyDataSetChanged();//刷新界面
} //XRecyclerView的点击事件
adapter_all.setmOnItemListener(new Adapter_RecyclerView.OnItemListener() {
@Override
public void onItemClick(int position) {
//Intent跳转
Intent intent = new Intent(getActivity(), All_Activity.class);
intent.putExtra("roomid", data.get(position).getRoomid());
startActivity(intent);
}
}); /**
*设定下拉刷新和上拉加载监听
*/
RV_all.setLoadingListener(new XRecyclerView.LoadingListener() {
//上拉加载监听
@Override
public void onLoadMore() {
i++;//上拉加载添加数据
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
con=1;//con不等于0就执行上啦加载
okhttp(i);//okhttp解析数据
RV_all.loadMoreComplete(); //加载数据完成(取消加载动画)
}
},2000);
}
//下拉刷新监听
@Override
public void onRefresh() {
//清除集合
data.clear();
okhttp(0);//初始化数据
new Handler().postDelayed(new Runnable() {
@Override
public void run() {
adapter_all.notifyDataSetChanged();//刷新界面
RV_all.refreshComplete(); //刷新数据完成(取消刷新动画)
}
},2000);
}
}); }
private void initView(View inflate) {
RV_all = (XRecyclerView) inflate.findViewById(R.id.RV_all);
}
}

适配器:


public class Adapter_All extends XRecyclerView.Adapter<Adapter_All.ViewHolder>{
private List<Bean_All.MessageBean.AnchorsBean> list;
private Context context; public Adapter_All(List<Bean_All.MessageBean.AnchorsBean> list, Context context) {
this.list = list;
this.context = context;
} @Override
public Adapter_All.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View inflate = LayoutInflater.from(context).inflate(R.layout.layout_all, parent, false);
ViewHolder viewHolder = new ViewHolder(inflate);
return viewHolder;
} @Override
public void onBindViewHolder(Adapter_All.ViewHolder holder, int position) {
Glide.with(context).load(list.get(position).getPic74()).into(holder.img_all);
holder.tv_name.setText(list.get(position).getName());
holder.tv_online.setText(""+list.get(position).getFocus()+"人");
} @Override
public int getItemCount() {
return list == null ? 0 : list.size();
} public class ViewHolder extends RecyclerView.ViewHolder { private final ImageView img_all;
private final TextView tv_name;
private final TextView tv_online; public ViewHolder(View itemView) {
super(itemView);
img_all = itemView.findViewById(R.id.img_all);
tv_name = itemView.findViewById(R.id.tv_name);
tv_online = itemView.findViewById(R.id.tv_online);
itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (mOnItemListener!=null){
mOnItemListener.onItemClick(getPosition());
}
}
});
}
}
public interface OnItemListener{
void onItemClick(int position);
}
public Adapter_RecyclerView.OnItemListener mOnItemListener;
public void setmOnItemListener(Adapter_RecyclerView.OnItemListener mOnItemListener){
this.mOnItemListener = mOnItemListener;
}
}

 
 

XRecyclerView上拉刷新下拉加载的更多相关文章

  1. jQuery模拟原生态App上拉刷新下拉加载

    jQuery模拟原生态App上拉刷新下拉加载效果代码,鼠标上拉时会显示loading字样,并且会模拟加载一条静态数据,支持触屏设备使用. <!doctype html> <html ...

  2. Android之 RecyclerView,CardView 详解和相对应的上拉刷新下拉加载

    随着 Google 推出了全新的设计语言 Material Design,还迎来了新的 Android 支持库 v7,其中就包含了 Material Design 设计语言中关于 Card 卡片概念的 ...

  3. Flutter学习笔记(25)--ListView实现上拉刷新下拉加载

    如需转载,请注明出处:Flutter学习笔记(25)--ListView实现上拉刷新下拉加载 前面我们有写过ListView的使用:Flutter学习笔记(12)--列表组件,当列表的数据非常多时,需 ...

  4. 微信小程序 上拉刷新/下拉加载

    小程序项目中上拉刷新下拉加载是比较常见的需求,官方文档也提供了相当友好的API,但是因为API隐藏的比较深,文档描述也比较模糊所以也折腾了一番(官方文档),在此记录一下使用方式 onPullDownR ...

  5. ListView上拉刷新和分页加载完整的Dome

    很多人工作的过程中都会碰到ListView下拉刷新和分页加载,然后大多数公司都已经把框架写好了,大家直接用就可以了,有些人一直对这个事情处于迷茫状态,为了让大家对上拉刷新和分页加载有一个比较全面的认识 ...

  6. jQuery WeUI 组件下拉刷新和滚动加载的实现

    最近在做手机版使用到了下拉刷新和滚动加载,记录一下实现过程: 一.引入文件 ? 1 2 3 4 <link rel="stylesheet" href="Conte ...

  7. 实现app上对csdn的文章列表上拉刷新下拉加载以及加入缓存文章列表的功能 (制作csdn app 四)

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/23698511 今天继续对我们的csdn客户端未完成的功能进行实现,本篇博客接着客 ...

  8. iOS:延迟加载和上拉刷新/下拉加载的实现

    lazy懒加载(延迟加载)UITableView 举个例子,当我们在用网易新闻App时,看着那么多的新闻,并不是所有的都是我们感兴趣的,有的时候我们只是很快的滑过,想要快速的略过不喜欢的内容,但是只要 ...

  9. MUI - 上拉刷新/下拉加载

    新闻信息列表必备的功能,支持Table,Ul等列表. 以下是DIV版本,在安卓端或者ios端必须使用双webview模式,传送门:http://dev.dcloud.net.cn/mui/pulldo ...

随机推荐

  1. Vue SSR不可不知的问题

    Vue SSR不可不知的问题 本文主要介绍Vue SSR(vue服务端渲染)的应用场景,开发中容易遇到的一些问题,提升ssr性能的方法,以及ssr的安全性问题. ssr的应用场景 1.SEO需求 SE ...

  2. Git+Hexo搭建个人博客详细过程

    通过Git+Hexo搭建的个人博客地址:https://liangh.top/ 1.安装Node.js.配置好Node.js环境.安装Git和配置好Git环境,打开cmd命令行,成功界面如下 2.安装 ...

  3. 使用 Infer.NET 进行概率编程

    本文介绍了如何使用 Infer.NET 进行概率性编程. 概率性编程是一种将自定义模型表示为计算机程序的机器学习方法. 借助它可以在模型中包含专业知识,使机器学习系统更易理解. 它还支持在线推断,即在 ...

  4. Android--通知之Notification

    前言 之前一篇博客讲了Android下使用Toast的方式提示消息.这篇博客讲解一下在Android中使用Notification提示消息给用户,Notification是一种具有全局效果的通知,程序 ...

  5. java各种集合的线程安全

    微信公众号[程序员江湖] 作者黄小斜,斜杠青年,某985硕士,阿里 Java 研发工程师,于 2018 年秋招拿到 BAT 头条.网易.滴滴等 8 个大厂 offer,目前致力于分享这几年的学习经验. ...

  6. 重学python

    sort dictionary mydict={"a":5,"b":1,"c":6}; sorted(mydict,key=mydict.g ...

  7. json数据格式说明

    格式说明 json文件由对象(集合).数组.key/value元素组成,可以相互嵌套. 使用大括号包围的是对象,使用中括号包围的是数组,冒号分隔的是元素. 元素的key只能是字符串. 元素的value ...

  8. 小型音乐播放器插件APlayer.js的简单使用例子

      本篇博客将会给出一个小型音乐播放器插件APlayer.js的使用例子.关于APlayer.js的具体介绍和Github地址,可以参考: https://github.com/MoePlayer/A ...

  9. 验证码图片二值化问题 BitmapData 怎么解决

    对不起,这算是一篇求助啦,先上图,防止不清楚,放大了一点,下面是图片,上面是没有二值化的,下面是二值化之后的,我其实不懂什么是二值化啦,就是一定范围变黑,变白 问题: 为什么我的结果上面还是有很多彩色 ...

  10. C#文件夹权限操作整理

    using System.Security.AccessControl; using System.IO; using System.Security.Principal; 取得目录的访问控制和审核安 ...