效果图:

首先要添加依赖:

//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. 深度解析使用CSS单位px、em、rem、vh、vw、vmin、vmax实现页面布局

     1.px:绝对单位,页面按精确像素展示 2.em:相对单位,基准点为父节点字体的大小,如果自身定义了font-size按自身来计算(浏览器默认字体是16px),整个页面内1em不是一个固定的值. e ...

  2. Spring Cloud微服务如何设计异常处理机制?

    导读 今天和大家聊一下在采用Spring Cloud进行微服务架构设计时,微服务之间调用时异常处理机制应该如何设计的问题.我们知道在进行微服务架构设计时,一个微服务一般来说不可避免地会同时面向内部和外 ...

  3. 2.matplotlib画散点图

    2.1.身高和体重实例 import matplotlib.pyplot as plt height = [161,162,163,164,165] weight = [50,60,70,80,90] ...

  4. Navicat 连接Oracle的教程以及注意事项

    今天使用Navicat 连接Oracle时晕倒了一些坑,特此记录一下! 楼主就是64位win10系统,安装的Navicat是64位的,刚开始配置32位的oci.配置后连接还是提示“Connot loa ...

  5. Gradle实现自动打包,签名,自定义apk文件名

    Gradle实现自动打包,签名,自定义apk文件名 什么是签名,签名有什么用 Android APP都需要我们用一个证书对应用进行数字签名,不然的话是无法安装到Android手机上的,平时我们调试运行 ...

  6. java jar 后台运行

    nohup java -jar $APP_NAME.jar >/dev/null &

  7. JavaScript经典片段

    typeof jQuery != "undefined" || importjQuery(); 判断jQuery对象是否存在,如果不存在就调用importjQuery()方法加载j ...

  8. 连载《一个程序猿的生命周期》-《发展篇》- 22.城市奋斗者的阿Q精神

    好久没有写文章了,有些人会认为博主肯定是没有什么好写的了.其实不然,是想写的太多,实在是没有时间.上半年一直比较忙,处于加班常态的状态,身心疲惫.相较于城市的伪奋斗者,我算比较实干的,而界定“实干”的 ...

  9. tomcat和nginx配置java服务器

    tomcat和nginx配置java服务器 环境配置 服务器配置  写了这么久的SSM,做了一个简单的网站[没有加入数据库],然后就要开始部署javaWEB的云服务器了.本次搭建使用的Tomcat和n ...

  10. TensorFlow中的通信机制——Rendezvous(二)gRPC传输

    背景 [作者:DeepLearningStack,阿里巴巴算法工程师,开源TensorFlow Contributor] 本篇是TensorFlow通信机制系列的第二篇文章,主要梳理使用gRPC网络传 ...