Android ListView加载更多

先看效果:

ListView的footer布局:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:paddingBottom="10dp"
android:paddingTop="10dp" >

<TextView
android:id="@+id/pulldown_footer_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="加载更多日志"
android:textSize="15dp" />

<ProgressBar
android:id="@+id/pulldown_footer_loading"
style="@android:style/Widget.ProgressBar.Small.Inverse"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_marginLeft="20dp"/>

</RelativeLayout>

ListView的item和main_activity布局很简单,分别是一个TextView和ListView,不再贴出。

MainActivity代码贴出:

import java.util.ArrayList;
import java.util.List;

import android.app.Activity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView.OnScrollListener;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.RelativeLayout;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends Activity
{
private ListView listview;
private LayoutInflater inflater;
private List<String> arrays = new ArrayList<String>();
private RelativeLayout footer;
private MyAdapter adapter;
// 每页显示条数
private Integer perpage = 20;
// 当前页数
private Integer currentpage = 1;
// 最大页数
private Integer maxpage = 1;

@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

setMaxPage(40);
loadData(currentpage, perpage);

inflater = getLayoutInflater();
listview = (ListView) this.findViewById(R.id.pulldownview);
footer = (RelativeLayout) View.inflate(getApplicationContext(), R.layout.pulldown_footer, null);
listview.addFooterView(footer, null, true);
adapter = new MyAdapter();
listview.setAdapter(adapter);
listview.setOnScrollListener(new OnScrollListener()
{

@Override
public void onScrollStateChanged(AbsListView view, int scrollState)
{
if (view.getLastVisiblePosition() == view.getCount() - 1)
{
if (currentpage != maxpage)
{
currentpage++;
loadData(currentpage, perpage);
adapter.notifyDataSetChanged();
} else
{
Toast.makeText(getApplicationContext(), "没有更多的数据!", Toast.LENGTH_SHORT).show();
listview.removeFooterView(footer);
}
}
}

@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount)
{

}
});
}

/**
* 模拟分页查询数据
*
* @param currentpage当前页数
* @param perpage
* 每页显示数
*/
private void loadData(Integer currentpage, Integer perpage)
{
// 起始数据
Integer firstResult = (currentpage - 1) * perpage;
// 获取的最大数据
Integer maxResult = currentpage * perpage;
System.out.println("firstResult:"+firstResult+" "+"maxResult:"+maxResult);
// select * from database where XXXX order by XX limit firstResult,maxResult //order by可省略,但有order by时limit必需在它后面
for (; firstResult < maxResult; firstResult++)
{
arrays.add("这是测试数据" + (firstResult+1));
}
}

/**
* 模拟获取最大页数
*
* @param total
* 总的数据
*/
private void setMaxPage(Integer total)
{
if (total % perpage == 0)
{
maxpage = total / perpage;
} else
{
maxpage = total / perpage + 1;
}
System.out.println("maxpage:"+maxpage);
}

private class MyAdapter extends BaseAdapter
{

@Override
public int getCount()
{
return arrays == null ? 0 : arrays.size();
}

@Override
public Object getItem(int position)
{
return null;
}

@Override
public long getItemId(int position)
{
return 0;
}

@Override
public View getView(int position, View convertView, ViewGroup parent)
{
ViewHolder holder;
if (convertView == null)
{
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.item_list, null);
holder.textView = (TextView) convertView.findViewById(R.id.text);
convertView.setTag(holder);
} else
{
holder = (ViewHolder) convertView.getTag();
}
holder.textView.setText(arrays.get(position));
return convertView;
}
}

private static class ViewHolder
{
TextView textView;
}
}

  

Android ListView加载更多,码迷,mamicode.com

时间: 2024-08-01 10:31:51

Android ListView加载更多的相关文章

Android listview 加载更多定位问题

我们用Android在做Listview加载更多数据时,如果每次都重新new Adapter的话,视图就会滑动到第一条. 后来我发现listview有一个方法可以获取最顶部时哪一个 int  position = mListView.getFirstVisiblePosition(); 这样就可以获取目前显示的第一行到底是多少条. 于是我有找到一个方法,加载更多数据后.我们设置一下他的选取位置,就不会有滚动到第一个条了 mListView.setSelection(position); 但是仔细

Listview 加载更多

JQM Listview 加载更多 demo - Warren的个人主页 JQM Listview 加载更多 Demo 测试数据1 测试数据2 测试数据3 测试数据4 显示更多 Page Footer <!DOCTYPE HTML> <html> <head> <title>JQM Listview 加载更多 demo - Warren的个人主页</title> <meta name="keywords" content

【转】Android ListView加载不同的item布局

原创教程,转载请保留出处:http://www.eoeandroid.com/thread-72369-1-1.html 最近有需求需要在listView中载入不同的listItem布局,开始没有使用convertView,加载了多个item后导致了内存泄露,所以回来研究convertView在多个listItem布局时的缓存及应用,并且和大家分享 构造Adapter时,没有使用缓存的 convertView,导致内存泄露 示例代码:public View getView(int positio

android listview 加载遇到的问题

http://blog.csdn.net/l_serein/article/details/7706338 转载: 描述一下场景: 菜单栏上有若干分类,点击每一个分类,ListView下分根据分类显示出相应的内容. -------------------------- 1.切换分类时出现异常.描述如下: E/AndroidRuntime(8131): java.lang.IndexOutOfBoundsException: Invalid index 11, size is 0 E/Androi

Listview加载更多是,恢复到原来的位置,如果不加特殊处理,总是跳转第一条

1.记录listView滚动到的位置的坐标,然后利用listView.scrollTo精确的进行恢复 listView.setOnScrollListener(new OnScrollListener() { /** * 滚动状态改变时调用 */ @Override public void onScrollStateChanged(AbsListView view, int scrollState) { // 不滚动时保存当前滚动到的位置 if (scrollState == OnScrollL

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

Android上拉加载更多ListView——PulmListView

思路 今天带大家实现一个上拉加载更多的ListView.GitHub传送门:PulmListView, 欢迎大家fork&&star. 先带大家理一下思路, 如果我们要实现一个上拉加载更多的ListView, 我们需要实现的功能包括: 一个自定义的ListView, 并且该ListView能够判断当前是否已经处于最底部. 一个自定义的FooterView, 用于在ListView加载更多的过程中进行UI展示. 关联FooterView和ListView, 包括加载时机判断.FooterVi

Android Demo之旅 ListView底部添加加载更多按钮实现数据分页

在我们的实际项目中,数据应该说是很多的,我们的ListView不可能一下子把数据全部加载进来,我们可以当滚动条滚动到ListView的底部的时候,给一个更多的提示,当我们点击它即加载下一页的数据,相当与我们的分页效果,参考网上的东西,写了一个小小的demo,并总结了一些知识点,功能图如下:    源代码下载地址:http://download.csdn.net/detail/harderxin/7762625 掌握知识点: 1)自定义Adapter,将数据和ListView绑定起来 2)理解La

硅谷新闻6--下拉刷新/上拉加载更多

 1.添加加载更多布局 1_初始化和隐藏代码在RefreshListView构造方法中调用 private void initFooterView(Context context) { View footerView = View.inflate(context, R.layout.refresh_listview_footer, null); //隐藏代码 footerView.measure(0, 0); int footerViewHeight = footerView.getMeasur