(转载声明出处:http://www.cnblogs.com/linguanh/)

简介:
      该ListView 实现动态加载数据,为了方便用户充分地自定义自己的数据源、点击事件,等核心操作,本类采用接口形式提供上述具体操作!
      1,所有关键的操作使用接口,由用户自己定义,
              包括:数据适配器的配置、动态加载函数的配置、item点击接口;
      2,已经新建线程来执行动态函数。
      //3,提供一个默认的动态执行函数;

用法:

你只需要在自己的 activity、fragment或者其他,之后调用其构造函数new 一个该类对象,同时传入你的 ListView,然后再继承它的两个接口:

configAdapterForListView、configRefreshData;

通过 两行代码绑定接口:

setConfigListviewAdapterListener(this)

setConfigRefreshDataListener(this)

共重写 4 个函数,分别是:

     @Override
public SimpleAdapter configSimpleAdapter() {
//在这里配置 SimpleAdapter,再返回,默认返回null
return null;
} @Override
public ArrayAdapter configArrayAdapter() {
//在这里配置 ArrayAdapter
return null;
} @Override
public void configOnItemClick(AdapterView<?> parent, View view, int position, long id) {
// 在这里处理 listView的 点击事件
} @Override
public void refreshData() {
//在这里处理 加载操作,无需再新建线程执行
}

最后通过调用 setListviewAdapter();完成所有操作,这个函数执行后,它会自动调用,上述两个数据适配器接口,和你传进去的ListView 进行 绑定。

其他数据适配器,可以自行添加,或者重写我的类进行修改,相信你绝对看得懂!

代码:

 package com.lgh.addItemListview;

 import android.content.Context;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter; import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; /**
* Created by LinGuanHong on 2015/7/14.
* 简介:
* 该ListView 实现动态加载数据
* 1,所有关键的操作使用接口,由用户自己定义,
* 包括:数据适配器的配置、动态加载函数的配置、item点击接口;
* 2,已经新建线程来执行动态函数。
* //3,提供一个默认的动态执行函数;
*/
public class mainListview implements AbsListView.OnScrollListener,AdapterView.OnItemClickListener { private Boolean isSimpleDapter = false;//默认是 ArrayAdapter
private Boolean refreshAble = false;//防止一直刷新
private List<Map<String,Object>> defaultDataList;
private configAdapterForListView adapter;
private configRefreshData refresh;
private ListView listview;
private Handler dealHandler;
private int defaultDataSize;
private Context context; public mainListview(Context context,ListView listview){
this.context = context;
if(listview!=null){
this.listview = listview;
43 initAll();
}
} public void setConfigListviewAdapterListener(configAdapterForListView adapter){
this.adapter = adapter;
} private configAdapterForListView getListviewAdapterListener(){
return adapter;
} public void setConfigRefreshDataListener(configRefreshData refresh){
this.refresh = refresh;
} private configRefreshData getConfigRefreshDataListener(){
return refresh;
} void initAll(){
initHandler();
listview.setOnScrollListener(this);
listview.setOnItemClickListener(this);
} public void setListviewAdapter(){
if(listview!=null){
if((getListviewAdapterListener().configArrayAdapter())!=null){
listview.setAdapter(getListviewAdapterListener().configArrayAdapter());
}else if((getListviewAdapterListener().configSimpleAdapter())!=null){
isSimpleDapter=true;
listview.setAdapter(getListviewAdapterListener().configSimpleAdapter());
}
}else{ }
} void initHandler(){
dealHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if(msg.what==1){
if(isSimpleDapter){ //判断用户选择的是何种适配器
getListviewAdapterListener().configArrayAdapter().notifyDataSetChanged();
//refreshAble = true;
}else{
getListviewAdapterListener().configArrayAdapter().notifyDataSetChanged();
//refreshAble = true;
}
}
}
};
} //为了优化内存,由用户自己选择是否启用默认数据
public void setDefaultDataList(int defaultDataSize){
this.defaultDataSize = defaultDataSize;
defaultDataList = new ArrayList<Map<String, Object>>();
} public List<Map<String,Object>> defaultRefreshDataFunction(){
for(int i=0;i<defaultDataSize;i++){
Map<String,Object> map = new HashMap<String, Object>();
//默认的操作
}
return defaultDataList;
} @Override
public void onScrollStateChanged(AbsListView view, int scrollState) { } @Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
//firstVisibleItem:当前能看见的第一个列表项ID(从0开始)
//visibleItemCount:当前能看见的列表项个数(小半个也算)
//totalItemCount:列表项共数
if(firstVisibleItem+visibleItemCount==totalItemCount && totalItemCount>0){
new Thread(new Runnable() {
@Override
public void run() {
getConfigRefreshDataListener().refreshData();//执行更新接口
Message msg = new Message();
msg.what = 1;
dealHandler.sendMessage(msg);
}
}).start();
}
} @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
getListviewAdapterListener().configOnItemClick(parent,view,position,id);//调用 item接口点击
} public interface configAdapterForListView{
//配置 SimpleAdapter数据适配器接口
public SimpleAdapter configSimpleAdapter();
// 配置 ArrayAdapter 数据适配器接口
public ArrayAdapter configArrayAdapter();
// item 点击事件接口
public void configOnItemClick(AdapterView<?> parent, View view, int position, long id);
} public interface configRefreshData{
//实现这个接口来设置用户下滑时,动态加载数据 接口
public void refreshData();
}
}

测试例子 activity

 import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.SimpleAdapter; import com.lgh.addItemListview.mainListview; import java.util.ArrayList;
import java.util.List; public class MainActivity extends Activity implements
mainListview.configAdapterForListView,mainListview.configRefreshData { ArrayAdapter<String> adapter;
List<String> res = new ArrayList<String>() ;
private ListView myListview;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.testlv);
for(int j = 0;j<20;j++){
res.add("beijing");
}
myListview = (ListView) findViewById(R.id.lv);
mainListview test = new mainListview(this,myListview);
test.setConfigListviewAdapterListener(this);
test.setConfigRefreshDataListener(this);
adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,res);
test.setListviewAdapter();
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
} @Override
public SimpleAdapter configSimpleAdapter() { return null;
} @Override
public ArrayAdapter configArrayAdapter() {
return adapter;
} @Override
public void configOnItemClick(AdapterView<?> parent, View view, int position, long id) {
// 在这里处理 listView的 点击事件
} @Override
public void refreshData() {
addString();
} void addString(){
res.add("i am the new");
}
public List<String> getData(){
return res;
}
}

分享个刚写好的 android 的 ListView 动态加载类,功能全而代码少。的更多相关文章

  1. Android中ListView动态加载数据

    1. 引言: 为了提高ListView的效率和应用程序的性能,在Android应用程序中不应该一次性加载ListView所要显示的全部信息,而是采取分批加载策略,随着用户的滑动,动态的从后台加载所需的 ...

  2. Android 自定义ListView动态加载数据

    我们都知道网络取数据是耗时操作,如果我们一次性请求所有数据,假如数据量不多那还可以接受,但是如果数据量特别多,那么带来的后果就是用户的愤怒(用户是很没有耐心的),所以这时候我们就需要动态的加载数据,分 ...

  3. wemall app商城源码Android之ListView异步加载网络图片(优化缓存机制)

    wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之L ...

  4. Android中的动态加载机制

    在目前的软硬件环境下,Native App与Web App在用户体验上有着明显的优势,但在实际项目中有些会因为业务的频繁变更而频繁的升级客户端,造成较差的用户体验,而这也恰恰是Web App的优势.本 ...

  5. Android的ListView异步加载图片时,错位、重复、闪烁问题的分析及解决方法

    Android ListView异步加载图片错位.重复.闪烁分析以及解决方案,具体问题分析以及解决方案请看下文. 我们在使用ListView异步加载图片的时候,在快速滑动或者网络不好的情况下,会出现图 ...

  6. Android中ListView异步加载图片错位、重复、闪烁问题分析及解决方案

    我们在使用ListView异步加载图片的时候,在快速滑动或者网络不好的情况下,会出现图片错位.重复.闪烁等问题,其实这些问题总结起来就是一个问题,我们需要对这些问题进行ListView的优化. 比如L ...

  7. Android 实现布局动态加载

    Android 动态加载布局 通过使用LayoutInflater 每次点击按钮时候去读取布局文件,然后找到布局文件里面的各个VIEW 操作完VIEW 后加载进我们setContentView 方面里 ...

  8. Android开发技巧——TextView加载HTML的图片及代码显示问题

    前几天在做一个Gradle用户指南的应用程序,使用的是TextView来加载HTML内容(至于为什么不用WebView,我也没有认真使用并比较过,也许以后会换吧),其中遇见了一些纠结的问题,所幸主要的 ...

  9. [Android Pro] so 动态加载—解决sdk过大问题

    原文地址: https://blog.csdn.net/Rong_L/article/details/75212472 前言 相信Android 开发中大家或多或少都会集成一些第三方sdk, 而其中难 ...

随机推荐

  1. Apache error: 403 Forbidden You don't have permission to access

    CentOS 6 solution: chcon -t httpd_sys_content_t -R /directory refer to: https://www.centos.org/forum ...

  2. 字符串、数组方法实战--charAt(),split(),indexOf(),substring()

    这篇随笔根据两个面试题来实战一下数组.字符串的一些方法. 题一:一个字符串中找出出现次数最多的字符次数 var str = 'fuuhuhuhufaihuhfnkjNKCNIO';
 function ...

  3. Openssl生成证书三板斧

    证书创建三步曲: 一.密钥文件 二.请求文 三.根证书签名 最后看需要是否合并证书文件 1. 创立根证书密钥文件(自己做CA)root.key: [kk@test ~]$ openssl genrsa ...

  4. Python之路Day12--mysql介绍及操作

    上节回顾: 1. RabbitMQ a. 平均分发 b. perfetch = 1 c. durable 队列持久化  deliver_mode = 2 消息持久化 d. 1对多广播  exchang ...

  5. Centos7 Docker 多主机 容器互连--基于OVS

    来一张自己画的图,mark:2016年6月27日17:09:14 自己理解,如有错误 多谢指教. centos7, 部署OVS和docker.以及基于centos6.8的ssh images 命令. ...

  6. 关于IoCallDriver使用的疑惑

    #pragma PAGEDCODE NTSTATUS HelloDDKRead(IN PDEVICE_OBJECT pDevObj, IN PIRP pIrp) { KdPrint(("Dr ...

  7. 什么是jquery $ jQuery对象和DOM对象 和一些选择器

    1什么是jQuery: jQuery就是将一些方法封装在一个js文件中.就是个js库 我们学习这些方法. 2为什么要学习jQuery: 原生js有以下问题: 1.兼容性问题2.代码重复3.DOM提供的 ...

  8. HTTP method POST is not supported by this URL

    修改提交页面的提交方式,修改method为get(在index页面中html标签 method="get") 示例代码修改后的代码: <form action="s ...

  9. (翻译)《Hands-on Node.js》—— Introduction

    今天开始会和大熊君{{bb}}一起着手翻译node的系列外文书籍,大熊负责翻译<Node.js IN ACTION>一书,而我暂时负责翻译这本<Hands-on Node.js> ...

  10. 【腾讯Bugly干货分享】微信mars 的高性能日志模块 xlog

    本文来自于腾讯bugly开发者社区,未经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/581c2c46bef1702a2db3ae53 Dev Club 是一个交流移动 ...