做之前需要导入XListview的文件,此是用第三方的xListview实现的,东西没写全。此是在Fragment中实现的

//--------------XListView的布局----------------

<me.XListView android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/lv"></me.XListView>

//=============

package com.bw.test.fragment;

import java.io.BufferedInputStream;
import java.io.BufferedReader;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;

import me.XListView;
import me.XListView.IXListViewListener;

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;

import com.bw.test.R;
import com.bw.test.adapter.MyAdapter;
import com.bw.test.bean.News;

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v4.app.Fragment;
import android.util.Log;
import android.util.Xml;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ListView;

//-----设置了xlistview的监听
public class Fragment1 extends Fragment implements IXListViewListener{
    private XListView lv;
    private MyAdapter adapter;
    //定义一个页数
    private int ye=1;
    //封装一个集合    
    private List<News> news=new ArrayList<News>();
    private int STATE_1 = 1;
    private int STATE_2 = 2;
    private int STATE_3;
//----------------------------------------    
    //使用Handler    更新UI        
    private Handler handler=new Handler(){
        public void handleMessage(Message msg) {
            switch (msg.what) {
            case 0:    
                //获得线程发来的数据
                String text=(String) msg.obj;
                //XML解析
                toXml(text);                
                break;

default:
                break;
            }
        }

};
//--------------------------------------
    //使用PUll解析XML
    private void toXml(String text) {
        News newss=null;
        
        try {
             //判断,如果有数据先清空----如果让他显示上一页的数据就不用清空集合
            if (STATE_3 == STATE_1) {
                news .clear();
            }
            XmlPullParser parser=Xml.newPullParser();
            ByteArrayInputStream byteArrayInputStream=new ByteArrayInputStream(text.getBytes());
            parser.setInput(byteArrayInputStream, "utf-8");
            int eventType=parser.getEventType();
            while (eventType!=XmlPullParser.END_DOCUMENT) {
                String name=parser.getName();
                switch (eventType) {
                case XmlPullParser.START_TAG:
                    if (name.equals("news")) {
                        newss=new News();
                    }else if (name.equals("id")) {
                        String id=parser.nextText();
                        newss.setId(id);                        
                    }
                    else if (name.equals("title")) {
                        String title=parser.nextText();
                        newss.setTitle(title);                        
                    }
                    else if (name.equals("body")) {
                        String body=parser.nextText();
                        newss.setBody(body);                        
                    }
                    else if (name.equals("commentCount")) {
                        String commentCount=parser.nextText();
                        newss.setCommentCount(commentCount);                        
                    }
                    else if (name.equals("author")) {
                        String author=parser.nextText();
                        newss.setAuthor(author);                        
                    }
                    else if (name.equals("pubDate")) {
                        String pubDate=parser.nextText();
                        newss.setPubDate(pubDate);                        
                    }
                    else if (name.equals("url")) {
                        String url=parser.nextText();
                        newss.setUrl(url);                        
                    }
                                        
                    break;
                    
                    case XmlPullParser.END_TAG:
                        if (name.equals("news")) {
                            news.add(newss);
                                                        
                            //更新适配器
                             if (adapter == null) {
                                    adapter = new MyAdapter(news,getActivity());
                                    lv.setAdapter(adapter);
                                } else {
                                    adapter .notifyDataSetChanged();
                                }
                             //加载数据
                                load();

}
                        break;

default:
                    break;
                }
                
                eventType=parser.next();
                
            }
        } catch (XmlPullParserException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        
    };
    
//-----------------------------------------    
    private void load() {
        //停止更新
        lv.stopRefresh();
        //加载更多
        lv.stopLoadMore();
        //更新时间
        lv.setRefreshTime("刚刚");
        
    }

//------------------------------------------
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View view=inflater.inflate(R.layout.fragment1_item, null);
        lv=(XListView) view.findViewById(R.id.lv);
        lv.setPullLoadEnable(true);
        
        
        huodeshuju(ye);
        adapter = new MyAdapter(news, getActivity());
        lv.setAdapter(adapter);
        
        lv.setXListViewListener(this);
        return view;
    }
    
//---------------------------------------    
    //获得网络数据的方法
    private void huodeshuju(final int ye) {
        //创建子线程,做耗时的操作,请求网络数据
        new Thread(){
            public void run() {
                try {
                    //URL传入页数
                    URL url=new URL("http://www.oschina.net/action/api/news_list?catalog=1&pageIndex="+ye+"&pageSize=20");
                    HttpURLConnection urlConnection=(HttpURLConnection) url.openConnection();
                    urlConnection.setConnectTimeout(5000);
                    urlConnection.setReadTimeout(5000);
                    urlConnection.setRequestMethod("GET");
                    urlConnection.connect();
                    int code=urlConnection.getResponseCode();
                    if (code==200) {
                        InputStream inputStream=urlConnection.getInputStream();
                        BufferedReader reader=new BufferedReader(new InputStreamReader(inputStream));
                        String liner;
                        StringBuffer buffer=new StringBuffer();
                        while ((liner=reader.readLine())!=null) {
                            buffer.append(liner);
                            
                        }
                        String str=buffer.toString();
                        Log.i("-------------", str);
                        Message message=new Message();
                        message.what=0;
                        message.obj=str;
                        //发送消息
                        handler.sendMessage(message);
                    }
                    
                } catch (MalformedURLException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            };
        }.start();
        
        
        
    }
    
//--------------------------------
//实现xlistView监听方法的下拉刷新
    @Override
    public void onRefresh() {
         STATE_3 = STATE_1;//设置判断
        //获得网络数据
         //下拉刷新时,将页数在设为1,从第一页开始
         ye=1;
         huodeshuju(ye);                 
    }
    
//--------------------------------------
//实现xlistView监听方法的上拉加载更多
    @Override
    public void onLoadMore() {
        STATE_3 = STATE_2;
        //每一次上拉,让页数加1
        ye++;
        Log.i("页", ye+"");
        //获得网络数据
        huodeshuju(ye);
        Log.i("页222", ye+"");
        
    }

}

//==========无用参考================

//继承IXListViewListener
public class MainActivity extends Activity implements OnItemClickListener,IXListViewListener

private int STATE_1 = 1;
   private int STATE_2 = 2;
   private int STATE_3;

lv2 = (XListView) findViewById(R.id.lv);
lv2.setPullLoadEnable(true);//上拉刷新
lv2.setXListViewListener(this);//给xListView设置监听

//判断,如果有数据先清空
 if (STATE_3 == STATE_1) {
                news .clear();
  }

//更新适配器
if (adapter == null) {
     adapter = new MyAdapter(news,this);
          lv2.setAdapter(adapter);
    } else {
     adapter .notifyDataSetChanged();
     }
     load();

public  void load(){
        //停止更新
        lv2.stopRefresh();
        //加载更多
        lv2.stopLoadMore();
        //更新时间
        lv2.setRefreshTime("刚刚");
    }

@Override
    public void onRefresh() {
         STATE_3 = STATE_1;//设置判断
         huodeshuju();
    }

@Override
    public void onLoadMore() {
        STATE_3 = STATE_2;
        huodeshuju();
    }

XListview的下拉刷新、上拉加载、用Pull解析XML的更多相关文章

  1. 第三方 XListview 上拉加载、下拉刷新、分页加载和Gson解析

    注意:此Demo用的是第三方的Xlistview.jar,需要复制me文件夹到项目中,两个XML布局文件和一张图片 把下面的复制到String中 <string name="xlist ...

  2. Android 下拉刷新上啦加载SmartRefreshLayout + RecyclerView

    在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/de ...

  3. SwipeRefreshLayout实现下拉刷新上滑加载

    1. 效果图 2.RefreshLayout.java package myapplication.com.myapplication; import android.content.Context; ...

  4. 移动端下拉刷新上拉加载-mescroll.js插件

    最近无意间看到有这么一个上拉刷新下拉加载的插件 -- mescroll.js,个人感觉挺好用的,官网地址是:http://www.mescroll.com 然后我就看了一下文档,简单的写了一个小dem ...

  5. ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多

    ListView实现Item上下拖动交换位置  并且实现下拉刷新  上拉加载更多 package com.example.ListViewDragItem; import android.app.Ac ...

  6. 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载

    title: 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载 tags: -RecyclerView,下拉刷新,上拉加载更多 grammar_cjkRuby: true - ...

  7. [ionic开源项目教程] - 第7讲 实现下拉刷新上拉加载ion-refresher和ion-infinite-scroll

    第7讲 实现下拉刷新上拉加载ion-refresher和ion-infinite-scroll 1.将tab1.html的代码改为如下: <ion-content> <ion-ref ...

  8. JS+CSS实现的下拉刷新/上拉加载插件

    闲来无事,写了一个当下比较常见的下拉刷新/上拉加载的jquery插件,代码记录在这里,有兴趣将代码写成插件与npm包可以留言. 体验地址:http://owenliang.github.io/pull ...

  9. 基于SwiperJs的H5/移动端下拉刷新上拉加载更多的效果

    最早时,公司的H5项目中曾用过点击一个"加载更多"的DOM元素来实现分页的功能,后来又用过网上有人写的一个上拉加载更多的插件,那个插件是页面将要滚动到底部时就自动请求数据并插入到页 ...

  10. ListView下拉刷新上拉加载更多实现

    这篇文章将带大家了解listview下拉刷新和上拉加载更多的实现过程,先看效果(注:图片中listview中的阴影可以加上属性android:fadingEdge="none"去掉 ...

随机推荐

  1. openwrt杂记

    /etc/config/wireless是在boot启动时生成的. 代码在/etc/init.d/boot中,如下: /sbin/wifi detect > /tmp/wireless.tmp  ...

  2. Excel教程(14) - 文本和数据函数

    ASC 用途:将字符串中的全角(双字节)英文字母更改为半角 (单字节)字符.   语法:ASC(text) 参数:Text 为文本或包含文本的单元格引用.如果文本 中不包含任何全角英文字母,则文本不会 ...

  3. Gentoo安装详解(四)-- 声卡设置

    硬件检测 To choose the right driver, first detect the used audio controller. You can use lspci for this ...

  4. 【Machine Learning in Action --4】朴素贝叶斯分类

    1.概述 朴素贝叶斯分类是贝叶斯分类器的一种,贝叶斯分类算法是统计学的一种分类方法,利用概率统计知识进行分类,其分类原理就是利用贝叶斯公式根据某对象的先验 概率计算出其后验概率(即该对象属于某一类的概 ...

  5. Python使用shape计算矩阵的行和列

    shape函数是numpy.core.fromnumeric中的函数,它的功能是读取矩阵的长度. 1 >>> a=mat([[1,2,3],[5,6,9]]); 2 >> ...

  6. MFC下调试日志的打印

    最近项目出现点小Bug,需要调试跟踪代码,于是乎写了份打印日志的代码. CLogFile.h文件 #if !defined(AFX_LOGFILE_H__288388CA_9A3E_4F3D_A2B8 ...

  7. slam相关知识

    Kinect视觉SLAM技术介绍 http://www.open-open.com/news/view/ce76e2 本文介绍SLAM的历史.理论以及实现的方式,且主要介绍基于视觉(Kinect)的实 ...

  8. WIN2003 设置 OPENVPN 服务端

    服务器端 安装openvpn 在这里http://swupdate.openvpn.org/community/releases/openvpn-install-2.3.4-I004-i686.exe ...

  9. VBS基础篇 - 对象(3) - FileSystemObject对象

    VBS基础篇 - 对象(3) - FileSystemObject对象   文件系统是所有操作系统最重要的部分之一,脚本经常会需要对文件及文件夹进行访问和管理,在Vbs中对桌面和文件系统进行访问的顶级 ...

  10. mysql常用命令使用技巧

    一.连接Mysql格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root - ...