MainActivity.java
package com.ct7.XListView.Main;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.Date;
import java.util.List;
import java.util.Locale;
import java.util.Timer;
import java.util.TimerTask;
import com.ct7.XListView.R;
import com.ct7.XListView.R.layout;
import com.ct7.XListView.R.menu;
import com.ct7.XListView.XListView;
import com.ct7.XListView.XListView.XListViewListener;
import android.os.Bundle;
import android.os.Handler;
import android.app.Activity;
import android.util.Log;
import android.view.Menu;
import android.widget.ArrayAdapter;
public class MainActivity extends Activity implements XListViewListener {
private List<String> items = new ArrayList<String>();
private int status = 0;
private XListView xListView;
private Handler handler;
private static int refershcount = 0;
private long refreshTime = 0;
private ArrayAdapter<String> adapter;
private SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
findView();
getItems();
xListView.setPullLoadEnable(true);// 拖动加载为 true
xListView.setAdapter(adapter = new ArrayAdapter<String>(
MainActivity.this, R.layout.activity_item, items));
setListener();
handler = new Handler();// 处理器
}
private void setListener() {
// TODO Auto-generated method stub
xListView.setXListViewListener(this);
}
private void findView() {
// TODO Auto-generated method stub
xListView = (XListView) findViewById(R.id.xListView);
}
// 获取数据
private void getItems() {
for (int i = 0; i < 20; ++i) {
items.add("测试数据" + (++status));
}
}
@Override
public void onRefresh() {
// TODO Auto-generated method stub
Log.v("bao", "onRefresh");
handler.postDelayed(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
status = refershcount;
items.clear();
getItems();// 获取数据
adapter = new ArrayAdapter<String>(MainActivity.this,
R.layout.activity_item, items);
xListView.setAdapter(adapter);
onLoad();
}
}, 500);
}
private void onLoad() {
xListView.stopRefresh();
xListView.stopLoadMore();
xListView.setRefreshTime("刚刚");
refreshTime = Calendar.getInstance(Locale.CHINA).getTime().getTime();
refreshTime();
}
public void refreshTime() {
Timer timer=new Timer();
timer.schedule(new TimerTask() {
@Override
public void run() {
// TODO Auto-generated method stub
findView();
getItems();
xListView.setPullLoadEnable(true);// 拖动加载为 true
xListView.setAdapter(adapter = new ArrayAdapter<String>(
MainActivity.this, R.layout.activity_item, items));
setListener();
adapter.setNotifyOnChange(true);//继续往下面加载 视图不会回到头部
xListView.setRefreshTime(dateFormat.format(refreshTime));
}
},5000);//当前时间开始5秒后启动
}
@Override
public void onLoadMore() {
// TODO Auto-generated method stub
handler.postDelayed(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
getItems();// 获取数据
adapter.setNotifyOnChange(true);//继续往下面加载 视图不会回到头部
//xListView.setAdapter(adapter);
onLoad();
}
}, 500);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
activity_main.xml:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world"/>
<com.ct7.XListView.XListView
android:id="@+id/xListView"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:cacheColorHint="#0000ff"
/>
</LinearLayout>
xlistview_header.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="bottom" >
<RelativeLayout
android:id="@+id/xlistview_header_content"
android:layout_width="fill_parent"
android:layout_height="60dp" >
<LinearLayout
android:id="@+id/xlistview_header_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:gravity="center"
android:orientation="vertical" >
<TextView
android:id="@+id/xlistview_header_hint_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="下拉刷新" />
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="3dp" >
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="上次更新时间:"
android:textSize="12sp" />
<TextView
android:id="@+id/xlistview_header_time"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="12sp" />
</LinearLayout>
</LinearLayout>
<ImageView
android:id="@+id/xlistview_header_arrow"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@id/xlistview_header_text"
android:layout_centerVertical="true"
android:layout_marginLeft="-35dp"
android:src="@drawable/xlistview_arrow" />
<ProgressBar
android:id="@+id/xlistview_header_progressbar"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_alignLeft="@id/xlistview_header_text"
android:layout_centerVertical="true"
android:layout_marginLeft="-40dp"
android:visibility="invisible" />
</RelativeLayout>
</LinearLayout>
xlistview_footer.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content" >
<RelativeLayout
android:id="@+id/xlistview_footer_content"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:padding="10dp" >
<ProgressBar
android:id="@+id/xlistview_footer_progressbar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:visibility="invisible" />
<TextView
android:id="@+id/xlistview_footer_hint_textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="查看更多" />
</RelativeLayout>
</LinearLayout>
activity_item.xml
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:textSize="26sp" >
</TextView>
项目的目录结构如下:
- 大小: 15.6 KB
分享到:
相关推荐
这个项目Demo是学习和了解XListView用法的一个理想起点。 一、XListView基础概念 1. 下拉刷新(Pull to Refresh):用户在顶部拉动列表,当滑动到最顶部时松手,列表会自动执行刷新操作,更新数据。 2. 上拉加载更...
7. **适配器**:XListView仍然使用Adapter来绑定数据,所以开发者需要创建自定义的Adapter,并重写其中的方法,如getView(),以显示列表项的内容。 8. **注意问题**:在实际使用中,需要注意数据加载的异步处理,...
在这个主题下,我们将探讨XlistView的基本概念、应用场景、使用方法以及如何通过提供的XlistViewDemo进行实践学习。 首先,XlistView通常是一个视图控件,用于高效地显示大量数据列表,具有滚动性能优良的特点。它...
本文将详细介绍`XListView`的使用方法,以及如何利用它来实现上拉加载更多和下拉刷新功能。 首先,`XListView`是一个开源项目,它继承自Android原生的ListView,并添加了上拉加载和下拉刷新的功能。开发者可以在不...
在本文中,我们将详细介绍XListView的特性、使用方法以及如何在项目中集成和自定义。 **1. XListView的主要特性** 1. **下拉刷新(Pull-to-Refresh)**:用户可以向下拉动列表,当达到一定阈值时,会触发刷新操作...
在实现水滴效果前,我们需要了解XListView的基本用法和API,例如设置下拉刷新监听器、上拉加载更多监听器以及相应的回调方法。 要实现水滴效果,我们需要做以下几步: 1. **自定义头部布局**:创建一个包含水滴...
在本文中,我们将深入探讨`XListView`的核心概念、用法以及它如何帮助开发者提升用户体验。 `XListView`最初由GitHub上的开源社区开发,它是在Android原生的`ListView`基础上进行了扩展,增加了底部加载更多数据的...
在移动应用开发中,XListView 是一个非常流行的 Android 第三方组件,它提供了强大的下拉刷新和上拉加载功能,能够实现列表的分页...通过理解其工作原理和使用方法,开发者可以为用户提供更加流畅、高效的浏览体验。
本篇将详细介绍`XListView`的原理、使用方法及其实现过程。 首先,下拉刷新(Pull to Refresh)是指用户在ListView顶部向下滑动时,可以触发刷新操作,更新数据。这个功能在现代移动应用中非常常见,使得用户能够...
这篇文档将详细介绍XListView的相关知识点,包括其原理、功能、使用方法以及可能遇到的问题。 XListView的核心功能是集成在ListView上的下拉刷新和上拉加载更多。在Android原生的ListView中,如果需要实现这些功能...
下面我们将深入探讨XListView的核心特性、如何集成以及使用技巧。 **XListView的核心特性** 1. **下拉刷新**:XListView提供了下拉刷新功能,用户只需轻轻一滑,列表顶部就会显示刷新进度条,更新数据后自动恢复到...
3. **初始化XListView**:在Activity或Fragment的onCreate方法中,找到XListView实例并设置监听器: ```java XListView xListView = findViewById(R.id.xlistview); xListView.setPullRefreshListener(new ...
在标题"使用XListView实现下拉刷新上拉加载更多"中,我们明确了目标:利用XListView库来为应用程序添加这两种交互功能。 导入XListView库通常是通过Gradle依赖进行的,这需要在项目的build.gradle文件中添加对应的...
本教程将详细讲解如何使用XListView来实现多条目网络数据的刷新加载,并结合网络加载图片的实践。 首先,我们需要在布局文件中添加XListView组件。XListView通常包含一个Header和Footer,Header用于下拉刷新,...
XListView是一款在Android平台上广泛使用的开源滚动列表框架,它扩展了Android原生的ListView组件,提供了丰富的下拉刷新和上拉加载更多功能。开发者可以通过集成XListView,轻松实现类似微博、微信等应用的下拉刷新...
本文将深入探讨如何使用xListView来实现这些功能。 首先,我们需要了解xListView的核心概念。下拉刷新(Pull to Refresh)允许用户通过手势向下拉动列表来更新数据,通常显示一个动画指示器,表示数据正在加载。上...
在这个专题中,我们将深入探讨XListView的基本用法、核心功能以及在实际项目中的应用。 一、XListView简介 XListView是由开源社区开发的一款可扩展的ListView,它继承自Android的AbsListView类,并添加了上拉刷新...
3. **初始化XListView**:在Activity或Fragment的onCreateView()方法中找到XListView并初始化,设置回调接口。 4. **实现回调**:重写onRefresh()和onLoadMore()方法,分别处理数据刷新和加载更多的逻辑。 5. **设置...
在移动应用开发中,"XListView_下拉刷新上拉加载"是一个常见的组件,它用于实现列表视图的滚动交互,比如用户向上滑动时触发数据的刷新,向...对于初学者来说,研究这些示例和文档将有助于快速掌握这一组件的使用方法。
2. 布局文件配置:在需要使用XListView的布局文件中,用XListView替换原始的ListView。 3. 设置监听器:通过设置`OnRefreshListener`和`OnLoadMoreListener`,处理上拉刷新和下拉加载的逻辑。 4. 更新数据:在监听器...