Android通过XListView实现上拉加载下拉刷新功能

本文实例为大家分享了XListView实现上拉加载下拉刷新的具体代码,供大家参考,具体内容如下

## 导入XListVIew第三方库文件。通过LinkedList将刷新数据插入到集合头部,将加载的数据放入集合尾部 ##
  private Context context;
  private View view;
  private String path;
  private XListView xlv;
  private LinkedList<Data> listData;

  private Handler handler = new Handler() {

    @SuppressWarnings("unchecked")
    public void handleMessage(android.os.Message msg) {

      int code = msg.arg1;
      if(msg.arg1==400){
        Toast.makeText(context, "数据格式解析不正确", 0).show();
      }
      else{
        NewsFragmentAdapter myAdapter = null;
        switch (code) {
        case 0:
          // 默认
          listData = (LinkedList<Data>) msg.obj;
          myAdapter = new NewsFragmentAdapter(context, listData);
          xlv.setAdapter(myAdapter);
          break;
        case 1:
          LinkedList<Data> shualist = (LinkedList<Data>) msg.obj;
          myAdapter = new NewsFragmentAdapter(context, shualist);
          for (int i = 0; i < shualist.size(); i++) {
            listData.addFirst(shualist.get(i));
          }
          myAdapter.notifyDataSetChanged();
          stopLoadOrRefresh();
          break;
        case 2:
          LinkedList<Data> loadlist = (LinkedList<Data>) msg.obj;
          myAdapter = new NewsFragmentAdapter(context, loadlist);
          for (int i = 0; i < loadlist.size(); i++) {
            listData.addLast(loadlist.get(i));
          }
          myAdapter.notifyDataSetChanged();
          stopLoadOrRefresh();
          break;
        default:
          break;
        }
      }
    };
  };

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    context=getActivity();
  }

  @Override
  public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    view = inflater.inflate(R.layout.fragment, container, false);

    path = getArguments().getString("path");

    // 配置Xlist
    xlv = (XListView) view.findViewById(R.id.xlv); // 获得控件
    xlv.setPullRefreshEnable(true);         // 设置可以下拉刷新
    xlv.setPullLoadEnable(true);          // 设置可以上拉加载
    xListViewListener();              // 调用XListView的监听方法

    if(path != null){
      getMessage(path, 0);            // 调用方法请求数据
    }

    itemClickListner();               // 调用XListView条目点击监听方法
    return view;
  }

  private void itemClickListner() {

    xlv.setOnItemClickListener(new OnItemClickListener() {
      @Override
      public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
        Intent intent=new Intent(context, WebViewActivity.class);
        intent.putExtra("path", listData.get(arg2-1).article_url);
        startActivity(intent);
      }
    });
  }

  public void xListViewListener() {
    xlv.setXListViewListener(new IXListViewListener() {

      // 当下拉刷新时实现的操作
      @Override
      public void onRefresh() {
        getMessage(path, 1);  // 请求网络,将新请求的内容加载到集合前端
      }

      // 当上拉加载时实现的操作内容
      @Override
      public void onLoadMore() { // 请求网络,将请求的新内容加载到集合后端
        getMessage(path, 2);
      }
    });

  }

  public void getMessage(String path, final int code) {

    HttpUtils utils = new HttpUtils();

    // 设置刷新间隔时间,如果不设置默认一分钟后才能刷新出新内容
    utils.configCurrentHttpCacheExpiry(0);

    utils.send(HttpMethod.GET, path, new RequestCallBack<String>() {

      // 请求网络失败回调的方法
      @Override
      public void onFailure(HttpException arg0, String arg1) {
      }

      // 请求网络成功回调的方法
      @Override
      public void onSuccess(ResponseInfo<String> arg0) {
        String info = arg0.result;

        Gson gson = new Gson();
        LinkedList<Data> list = gson.fromJson(info, ModelBean.class).data;
        Message message = new Message();
        if(list != null){
          message.arg1 = code;
          message.obj = list;
        }else{
          message.arg1=400;
        }
        handler.sendMessage(message);
      }
    });
  }

  private void stopLoadOrRefresh() {
    // 停止加载
    xlv.stopLoadMore();
    // 停止刷新
    xlv.stopRefresh();
    // 最近一次刷新时间
    xlv.setRefreshTime(getTime());
  }

  public String getTime() {
    // 格式化时间
    SimpleDateFormat format = new SimpleDateFormat("hh:mm:ss");
    Date date = new Date();
    String time = format.format(date);
    return time;
  }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • XListView实现下拉刷新和上拉加载原理解析

    XListview是一个非常受欢迎的下拉刷新控件,但是已经停止维护了.之前写过一篇XListview的使用介绍,用起来非常简单,这两天放假无聊,研究了下XListview的实现原理,学到了很多,今天分享给大家. 提前声明,为了让代码更好的理解,我对代码进行了部分删减和重构,如果大家想看原版代码,请去github自行下载. Xlistview项目主要是三部分:XlistView,XListViewHeader,XListViewFooter,分别是XListView主体.header.footer

  • Android XListView下拉刷新和上拉加载更多

    市面上有好多的类比ListView刷新数据的开源框架,如:v4包自带的SwipeRefreshLayout ,以及集ListView.GridView甚至WebView于一身的Pulltorefresh等等.前述的两个开源框架目前使用也算频繁.有兴趣的读者可以自行搜索,当然有时间一定回来对所有的使用方式做一个汇总和比较.今天介绍的这款框架,专门针对ListView做下拉刷新与上拉加载的,如果单单是ListView就显得更加简单方便易于理解. 1.首先引入xListView_lib库到自己的Dem

  • Android通过XListView实现上拉加载下拉刷新功能

    本文实例为大家分享了XListView实现上拉加载下拉刷新的具体代码,供大家参考,具体内容如下 ## 导入XListVIew第三方库文件.通过LinkedList将刷新数据插入到集合头部,将加载的数据放入集合尾部 ## private Context context; private View view; private String path; private XListView xlv; private LinkedList<Data> listData; private Handler

  • Android自定义listview布局实现上拉加载下拉刷新功能

    listview实现上拉加载以及下拉刷新的方式有很多.下面是我写的一种自定义的布局,复用性也比较的强.首先就是继承的listview的自定义view.   AutoListView.Java: package com.example.mic.testdemo.view; import android.annotation.TargetApi; import android.content.Context; import android.os.Build; import android.os.Bu

  • Android ListView实现上拉加载下拉刷新和滑动删除功能

    最近项目需要用到可以滑动删除并且带有上拉加载下拉刷新的Listview,查阅了一些资料,大多都是在SwipeMenuListView的基础上去添加头部和底部View,来扩展上拉加载和下拉刷新的功能,不过需要手动的去绘制UI及处理一些动画效果.用起来也不是特别方便.刚好项目中用到PulltorefreshLibrary库,就尝试着扩展了一个PullToRefreshSwipeMenuListView类来实现需求.先看一下效果: 实现步骤 一.组合Pulltorefresh与SwipeMenuLis

  • 微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)

    微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一) 页面缓存的设置优化了页面加载,减少了频繁的调取接口,使用户在断网的情况下有更好的体验. 每个微信小程序都可以有自己的本地缓存,可以通过 wx.setStorage(wx.setStorageSync).wx.getStorage(wx.getStorageSync).wx.clearStorage(wx.clearStorageSync)可以对本地缓存进行设置.获取和清理.本地缓存最大为10MB. 注意: localSt

  • mescroll.js上拉加载下拉刷新组件使用详解

    本文实例为大家分享了上拉加载下拉刷新组件mescroll.js的具体代码,供大家参考,具体内容如下 附上链接地址http://www.mescroll.com/api.html#NPM,手机端和浏览器都能够使用,唯一推荐: 使用过程中要注意这些问题http://www.mescroll.com/qa.html: 使用注意事项: 1.引入的时候出问题及时看官方给出的解决方案(基本上都必须看): 2.react中一定要在dom渲染之后的方法(didMount)中初始化,因为这个需要拿到dom对象:

  • vue基于vant实现上拉加载下拉刷新的示例代码

    前言 普遍存在于各种app中的上拉加载下拉刷新功能大家都不陌生吧,一般来说,在数据量比较大的情况下,为了更快的渲染和给用户更好的观感体验,我们会将数据做分页处理,让其批量加载,这样一来,在渲染速度上,能给用户一个比较好的体验效果.话说回来,分页处理,也就是我们今天要讲的上拉加载和下拉刷新. 实现思路 下拉刷新: 请求接口赋完值后,将接口返回数据长度与总条数进行比较控制加载不加载的状态,在下拉刷新方法中定义起始页码为第一页,调整加载的状态为false,最后调用请求数据的接口方法,做适当轻提示即可.

  • Vue uni-app框架实现上拉加载下拉刷新功能

    目录 实现上拉加载更多 优化 实现下拉刷新 实现上拉加载更多 打开项目根目录中的pages.json配置文件,为subPackages分包中的商品goods_list页面配置上拉触底的距离: "subPackages": [ { "root": "subpkg", "pages": [ { "path": "goods_detail/goods_detail", "style&

  • Vue vant-ui框架实现上拉加载下拉刷新功能

    目录 知识点速记 基本用法 下拉刷新 代码实现 1.页面布局 2.样式 3.方法 下拉刷新效果: 知识点速记 基本用法 List通过loading和finished两个变量控制加载状态,当组件滚动到底部时,会触发load事件并将loading设置成true.此时可以发起异步操作并更新数据,数据更新完毕后,将loading设置成false即可.若数据已全部加载完毕,则直接将finished设置成true即可. 下拉刷新 List 组件可以与PullRefresh组件结合使用,实现下拉刷新的效果.

  • 微信小程序(六):列表上拉加载下拉刷新示例

    1.列表(本部分内容出入官方文档) 对于这个功能,微信小程序中并没有提供类似于Android中listview性质的控件,所以我们需要使用 wx:for 控制属性绑定一个数组,用数组中各项的数据重复渲染该组件,来达到列表的效果. <view wx:for="{{array}}"> {{index}}: {{item.message}} </view> Page({ data: { array: [{ message: 'foo', }, { message: '

  • vue.js整合vux中的上拉加载下拉刷新实例教程

    前言 Vux 是基于 Vue 和 Weui 开发的手机端页面 UI 组件库,开发初衷是满足公司的微信端表单需求,因为第三方的调查问卷表单系统在手机上实在比较丑(还是 PC 那一套样式适配了大小而已).于是用 vue 重构了表单组件,后来一发不可收拾把其他常用组件也一并开发了. 相比于 React 还是更喜欢用 Vue ,除了目前社区组件不多,周边构建工具还是比较完善的(作者也特别勤奋). 下面话不多说了,来一看看详细的介绍吧. 先上图 创建项目 使用vue-cli 创建一个vue项目 安装vux

随机推荐