XListview的下拉刷新、上拉加载、用Pull解析XML

做之前需要导入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();
    }

时间: 2024-11-06 17:45:56

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

最新Android ListView 下拉刷新 上滑加载

开发项目过程中基本都会用到listView的下拉刷新和上滑加载更多,之前大家最常用的应该是pull to refresh或它的变种版吧,google官方在最新的android.support.v4包中增加了一个新类SwipeRefreshLayout,地址 这个类的作用就是提供官方的下拉刷新,并且效果相当不错,而上拉加载更多则用我们自定义的listview,也是相当简单. 下拉刷新 简单的介绍下: 首先它是一个viewgroup,但是它只允许有一个子控件,子控件能是任何view,使用的时候,所在

十分钟实现ListView下拉刷新上滑加载更多

说到ListView下拉刷新几乎每个APP都会用到,所以ListView下拉刷新是很重要的,就像ListView优化一样是你必会的东西. ListView实现下拉刷新如果我们开发人员自己编写相对来说比较费事的,当我们使用第三方库之后我们再来开发这个功能就会省事很多.相比与自己实现可以少编写不少代码,Android-PullToRefresh库可以轻松实现ListView的下拉刷新功能. 要使用Android—PullToRefesh库对ListView实现下拉刷新要经过以下几个步骤: 1.下载A

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

在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/details/78781682 ,这里是看了之后,结合自己实际遇到的问题写的. 首先引入包. //下拉框 implementation 'com.android.support:recyclerview-v7:28.0.0-beta01' implementation 'com.scwang.smar

ListView的下拉刷新+上拉加载(已有demo)

1.XListView因为添加了Header,会导致存储的数据+1,所以赋值时需要position-1.补充:当去掉HeaderView时,position不用-1. 2.提个建议:上拉加载更多,最好在onCreate()中就执行setAdapter,然后不论是空数据.还是有数据,只用更新适配器就行了. 一.XListView 2.用法 导入图中的me.maxwin.view包 提供了两个接口: IXListViewListener:触发下拉刷新,上拉加载更多.实现此接口时,onLoadMore

SwipeRefreshLayout+RecyclerView实现下拉刷新上拉自动加载

在实际开发中,为了节省开发周期,下拉刷新上拉加载通常都会采取使用一些第三方库,典型的就是用PullToRefresh,XListView等等,还有就是谷歌推荐的SwipeRefreshLayout,可惜没有上拉加载功能,需要自己去实现一个上拉加载的脚View,再加上现在代替ListView的RecyclerView+CardView使用的频率也是也来也高,不得不说,CardView效果确实很好看,一个一个的小卡片,用户体验好,I like it!!!废话不说了,奔主题!今天也玩了一下SwipeR

Maxwin-z/XListView-Android(下拉刷新上拉加载)源码解析(一)

本次解析的内容,是github上一个用于下拉刷新上拉加载的控件xlistview,这个功能相信大家在开发的过程中会经常用到. 控件的源码地址是https://github.com/Maxwin-z/XListView-Android 在这个控件之前,我看过一些相同功能的控件,挑选后觉得XListView功能比较完善,而且易于理解.在android-open-project里面,有提到一个DropDownListView,个人使用过以后,觉得功能是具备了,但是操作体验不好,原因就是没有使用到Scr

android 安卓 listview 支持下拉刷新 上拉加载更多

[1]重写listView import java.text.SimpleDateFormat; import java.util.Date; import android.content.Context; import android.util.AttributeSet; import android.util.Log; import android.view.MotionEvent; import android.view.View; import android.view.ViewGrou

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

转载请注明出处:http://blog.csdn.net/lowprofile_coding/article/details/51321896 一 .前言 最近实在太忙,一个多礼拜没有更新文章了,于是今晚加班加点把demo写出来,现在都12点了才开始写文章. 1.我们的目标 把RecyclerView下拉刷新上拉加载更多加入到我们的开发者头条APP中. 2.效果图 3.实现步骤 找一个带上拉刷新下载加载更多的RecyclerView开源库,我们要站在巨人的肩膀上 下载下来自己先运行下demo,然

Android 下拉刷新上拉加载 多种应用场景 超级大放送(上)

转载请标明原文地址:http://blog.csdn.net/yalinfendou/article/details/47707017 关于Android下拉刷新上拉加载,网上的Demo太多太多了,这里不是介绍怎么去实现下拉刷新上拉加载,而是针对下拉刷新上拉加载常用的一些应用场景就行了一些总结,包含了下拉刷新上拉加载过程中遇到的一些手势冲突问题的解决方法(只能算是抛砖引玉). 去年9月的时候,那时自己正在独立做Android项目.记得刚刚写完那个ListView列表页面(木有下拉刷新,上拉加载)

vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件

vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件/库 一提到移动端的下拉刷新上拉翻页,你可能就会想到iScroll插件,没错iScroll是一个高性能,资源占用少,无依赖,多平台的javascript滚动插件.iScroll不仅仅是 滚动.它可以处理任何需要与用户进行移动交互的元素.在你的项目中包含仅仅4kb大小的iScroll,你的项目便拥有了滚动,缩放,平移,无限滚动,视差滚动,旋转功能.iScroll的强大毋庸置疑,本人也非常欢迎大家使用iScr