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();
}
XListview的下拉刷新、上拉加载、用Pull解析XML的更多相关文章
- 第三方 XListview 上拉加载、下拉刷新、分页加载和Gson解析
注意:此Demo用的是第三方的Xlistview.jar,需要复制me文件夹到项目中,两个XML布局文件和一张图片 把下面的复制到String中 <string name="xlist ...
- Android 下拉刷新上啦加载SmartRefreshLayout + RecyclerView
在弄android刷新的时候,可算是耗费了一番功夫,最后发觉有现成的控件,并且非常好用,这里记录一下. 原文是 https://blog.csdn.net/huangxin112/article/de ...
- SwipeRefreshLayout实现下拉刷新上滑加载
1. 效果图 2.RefreshLayout.java package myapplication.com.myapplication; import android.content.Context; ...
- 移动端下拉刷新上拉加载-mescroll.js插件
最近无意间看到有这么一个上拉刷新下拉加载的插件 -- mescroll.js,个人感觉挺好用的,官网地址是:http://www.mescroll.com 然后我就看了一下文档,简单的写了一个小dem ...
- ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多
ListView实现Item上下拖动交换位置 并且实现下拉刷新 上拉加载更多 package com.example.ListViewDragItem; import android.app.Ac ...
- 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载
title: 带你实现开发者头条APP(五)--RecyclerView下拉刷新上拉加载 tags: -RecyclerView,下拉刷新,上拉加载更多 grammar_cjkRuby: true - ...
- [ionic开源项目教程] - 第7讲 实现下拉刷新上拉加载ion-refresher和ion-infinite-scroll
第7讲 实现下拉刷新上拉加载ion-refresher和ion-infinite-scroll 1.将tab1.html的代码改为如下: <ion-content> <ion-ref ...
- JS+CSS实现的下拉刷新/上拉加载插件
闲来无事,写了一个当下比较常见的下拉刷新/上拉加载的jquery插件,代码记录在这里,有兴趣将代码写成插件与npm包可以留言. 体验地址:http://owenliang.github.io/pull ...
- 基于SwiperJs的H5/移动端下拉刷新上拉加载更多的效果
最早时,公司的H5项目中曾用过点击一个"加载更多"的DOM元素来实现分页的功能,后来又用过网上有人写的一个上拉加载更多的插件,那个插件是页面将要滚动到底部时就自动请求数据并插入到页 ...
- ListView下拉刷新上拉加载更多实现
这篇文章将带大家了解listview下拉刷新和上拉加载更多的实现过程,先看效果(注:图片中listview中的阴影可以加上属性android:fadingEdge="none"去掉 ...
随机推荐
- deb
1.APT方式 (1)普通安装:apt-get install softname1 softname2 …; (2)修复安装:apt-get -f install softname1 softname ...
- MySQL(2)-数据类型和Schema
一.数据类型 只介绍基本的数据类型. MySQL中选择合适的数据类型还是很有必要的,下面是一些通用原则: 小的就是好的 一般情况下,应该尽量使用可以正确存储数据的最小数据类型.更小的数据类型通常更快, ...
- kettle连接mysql
kettle连接mysql时出现问题
- RHCE备考倒计时
2014年7月31日 周四 上海考试 认证RHCE6
- lepus监控OS配置
Lepus通过snmp协议进行对操作系统数据采集,因此需要在监控机和被监控机开启snmp服务 snmp协议:简单网络管理协议(SNMP,Simple Network Management Protoc ...
- js预编译
先来做三个测试 eg1: var a; a = 1; function a() {}; console.log(a); eg2: var a; function a() {}; console.log ...
- Webdriver的设计模式:Page Object(页面模型)
设计思想:面向对象,将单个页面所有可能用到元素封装到一个page类中,并提供一些常用的方法,其属性就代表页面元素,普通方法代表对元素所做的操作 以博客园的登录页面为例: import org.open ...
- C# List 扩展排序
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Comm ...
- java多维数组
int a[][][] = {{{1,2},{1,2}},{{1,2},{1,2}}}; int b[][][] = new int[][][]{{{1,2},{1,2}},{{1,2},{1,2}} ...
- JavaScript高级程序设计:第八章
1.window对象——BOM的核心 BOM的核心对象时window,它表示浏览器的一个实例.在浏览器中,window对象有双重角色,它既是通过javascript访问浏览器窗口的一个接口,又是ECM ...