`
阅读更多
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
分享到:
评论

相关推荐

    XListView项目demo

    这个项目Demo是学习和了解XListView用法的一个理想起点。 一、XListView基础概念 1. 下拉刷新(Pull to Refresh):用户在顶部拉动列表,当滑动到最顶部时松手,列表会自动执行刷新操作,更新数据。 2. 上拉加载更...

    XlistView使用

    7. **适配器**:XListView仍然使用Adapter来绑定数据,所以开发者需要创建自定义的Adapter,并重写其中的方法,如getView(),以显示列表项的内容。 8. **注意问题**:在实际使用中,需要注意数据加载的异步处理,...

    XlistView的简单使用

    在这个主题下,我们将探讨XlistView的基本概念、应用场景、使用方法以及如何通过提供的XlistViewDemo进行实践学习。 首先,XlistView通常是一个视图控件,用于高效地显示大量数据列表,具有滚动性能优良的特点。它...

    XlistView的使用

    本文将详细介绍`XListView`的使用方法,以及如何利用它来实现上拉加载更多和下拉刷新功能。 首先,`XListView`是一个开源项目,它继承自Android原生的ListView,并添加了上拉加载和下拉刷新的功能。开发者可以在不...

    开源组件XListView的demo

    在本文中,我们将详细介绍XListView的特性、使用方法以及如何在项目中集成和自定义。 **1. XListView的主要特性** 1. **下拉刷新(Pull-to-Refresh)**:用户可以向下拉动列表,当达到一定阈值时,会触发刷新操作...

    XListView 水滴效果代码

    在实现水滴效果前,我们需要了解XListView的基本用法和API,例如设置下拉刷新监听器、上拉加载更多监听器以及相应的回调方法。 要实现水滴效果,我们需要做以下几步: 1. **自定义头部布局**:创建一个包含水滴...

    底部刷新的XListView

    在本文中,我们将深入探讨`XListView`的核心概念、用法以及它如何帮助开发者提升用户体验。 `XListView`最初由GitHub上的开源社区开发,它是在Android原生的`ListView`基础上进行了扩展,增加了底部加载更多数据的...

    xlistview 分页效果完美运行

    在移动应用开发中,XListView 是一个非常流行的 Android 第三方组件,它提供了强大的下拉刷新和上拉加载功能,能够实现列表的分页...通过理解其工作原理和使用方法,开发者可以为用户提供更加流畅、高效的浏览体验。

    xlistview demo

    本篇将详细介绍`XListView`的原理、使用方法及其实现过程。 首先,下拉刷新(Pull to Refresh)是指用户在ListView顶部向下滑动时,可以触发刷新操作,更新数据。这个功能在现代移动应用中非常常见,使得用户能够...

    XListView demo

    这篇文档将详细介绍XListView的相关知识点,包括其原理、功能、使用方法以及可能遇到的问题。 XListView的核心功能是集成在ListView上的下拉刷新和上拉加载更多。在Android原生的ListView中,如果需要实现这些功能...

    XListView的Demo

    下面我们将深入探讨XListView的核心特性、如何集成以及使用技巧。 **XListView的核心特性** 1. **下拉刷新**:XListView提供了下拉刷新功能,用户只需轻轻一滑,列表顶部就会显示刷新进度条,更新数据后自动恢复到...

    使用XListView实现listview的下拉刷新和上拉加载功能

    3. **初始化XListView**:在Activity或Fragment的onCreate方法中,找到XListView实例并设置监听器: ```java XListView xListView = findViewById(R.id.xlistview); xListView.setPullRefreshListener(new ...

    使用XListView实现下拉刷新上拉加载更多

    在标题"使用XListView实现下拉刷新上拉加载更多"中,我们明确了目标:利用XListView库来为应用程序添加这两种交互功能。 导入XListView库通常是通过Gradle依赖进行的,这需要在项目的build.gradle文件中添加对应的...

    XListView实现多条目网络数据刷新加载 网络加载图片

    本教程将详细讲解如何使用XListView来实现多条目网络数据的刷新加载,并结合网络加载图片的实践。 首先,我们需要在布局文件中添加XListView组件。XListView通常包含一个Header和Footer,Header用于下拉刷新,...

    XListView开源框架

    XListView是一款在Android平台上广泛使用的开源滚动列表框架,它扩展了Android原生的ListView组件,提供了丰富的下拉刷新和上拉加载更多功能。开发者可以通过集成XListView,轻松实现类似微博、微信等应用的下拉刷新...

    xListView实现下拉刷新,上拉加载更多

    本文将深入探讨如何使用xListView来实现这些功能。 首先,我们需要了解xListView的核心概念。下拉刷新(Pull to Refresh)允许用户通过手势向下拉动列表来更新数据,通常显示一个动画指示器,表示数据正在加载。上...

    xlistview的使用和解析

    在这个专题中,我们将深入探讨XListView的基本用法、核心功能以及在实际项目中的应用。 一、XListView简介 XListView是由开源社区开发的一款可扩展的ListView,它继承自Android的AbsListView类,并添加了上拉刷新...

    Android自定义ListView示意-XListView

    3. **初始化XListView**:在Activity或Fragment的onCreateView()方法中找到XListView并初始化,设置回调接口。 4. **实现回调**:重写onRefresh()和onLoadMore()方法,分别处理数据刷新和加载更多的逻辑。 5. **设置...

    xlistview_下拉刷新上拉加载

    在移动应用开发中,"XListView_下拉刷新上拉加载"是一个常见的组件,它用于实现列表视图的滚动交互,比如用户向上滑动时触发数据的刷新,向...对于初学者来说,研究这些示例和文档将有助于快速掌握这一组件的使用方法。

    自定义XListView

    2. 布局文件配置:在需要使用XListView的布局文件中,用XListView替换原始的ListView。 3. 设置监听器:通过设置`OnRefreshListener`和`OnLoadMoreListener`,处理上拉刷新和下拉加载的逻辑。 4. 更新数据:在监听器...

Global site tag (gtag.js) - Google Analytics