基本信息
源码名称:Android ListView自动检索
源码大小:1.61M
文件格式:.rar
开发语言:Java
更新时间:2014-10-31
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
package com.tmnw;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.Log;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AutoCompleteTextView;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity implements OnScrollListener,
OnItemClickListener {
private static final String TAG = "gjj";
private EditText edit_search;
/*----ListView MVC实现----*/
// model
List<String> data;//所有的List
List<String> newList;//输入关键字后新的list
// view
ListView lv;
// controller
MyAdapter adapter;
MainAdapter adapter2;
View header;
View footer;
Button scrollInfo;
Thread currentThread;
int size = 1;
AutoCompleteTextView cardNumAuto;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initWidget();
initData();
lv.setOnScrollListener(this);
lv.setOnItemClickListener(this);
}
// 初始化组件
private void initWidget() {
lv = (ListView) findViewById(R.id.list);
scrollInfo = (Button) findViewById(R.id.scroll_info);
header = getLayoutInflater().inflate(R.layout.simple_text, null);
((TextView) header.findViewById(R.id.text1)).setText("这是一个头部");
footer = getLayoutInflater().inflate(R.layout.simple_text, null);
((TextView) footer.findViewById(R.id.text1)).setText("加载中...");
edit_search = (EditText) findViewById(R.id.EditText01);
//为输入添加TextWatcher监听文字的变化
edit_search.addTextChangedListener(watcher);
//myQuery(null,null);
}
// 初始化绑定数据
private void initData() {
if (lv == null)
return;
// 第一步:获取数据源(model)
data = new ArrayList<String>();
appendData();
// 第二步:new一个适配器(controller)
// 参数1:Context
// 参数2:listview的item布局
// 参数3:数据填充在item布局下的那个控件id
// 参数4:填充的数据
// adapter = new ArrayAdapter<String>(this, R.layout.simple_text,
// R.id.text1, data);
adapter = new MyAdapter();
// 第三步:给listview设置适配器(view)
// addHeaderView和addFooterView一定要有一个在setAdapter之前调用
lv.addHeaderView(header, "header", true);
lv.setAdapter(adapter);
// 这里的参数null是数据,false说明是不能被选中的
// lv.addFooterView(footer, null, false);
// 设置尾部无分割线,头部不想要分割线同理
lv.setFooterDividersEnabled(false);
}
//当editetext变化时调用的方法,来判断所输入是否包含在所属数据中
private List<String> getNewData(String input_info) {
//遍历list
newList= new ArrayList<String>();
for (int i = 0; i < data.size(); i ) {
//如果遍历到的名字包含所输入字符串
if (data.get(i).contains(input_info)) {
//将遍历到的元素重新组成一个list
// newList= new ArrayList<String>();
newList.add(data.get(i));
}
}
return newList;
}
// 添加数据
private void appendData() {
if (data == null)
return;
for (int i = 0; i < 10; i ) {
data.add("" size );
}
}
TextWatcher watcher = new TextWatcher() {
@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
// TODO Auto-generated method stub
Log.d("=================", "onTextChanged is called!");
if (edit_search.getText()!=null) {
String input_info = edit_search.getText().toString();
newList = getNewData(input_info);
Log.i("哈哈",newList.toString());
adapter2 = new MainAdapter();
lv.addHeaderView(header, "header", true);
lv.setAdapter(adapter2);
}
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count,
int after) {
// TODO Auto-generated method stub
Log.d("===============", "beforTextChanged is called");
}
@Override
public void afterTextChanged(Editable s) {
// TODO Auto-generated method stub
Log.d("=================", "afterTextChanged is called!");
}
};
// 模拟加载数据
class DataLoadThread extends Thread {
@Override
public void run() {
try {
Thread.sleep(2000);
appendData();
// 因为Android控件只能通过主线程(ui线程)更新,所以用此方法
runOnUiThread(new Runnable() {
@Override
public void run() {
// 加载完毕,移除尾部控件
lv.removeFooterView(footer);
// 当数据改变时调用此方法通知view更新
adapter.notifyDataSetChanged();
}
});
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
class MainAdapter extends BaseAdapter{
@Override
public int getCount() {
return newList.size();
}
@Override
public Object getItem(int position) {
Log.i(TAG, "position:" position);
return newList.get(position);
}
// itemId
@Override
public long getItemId(int position) {
return position;
}
// lv显示几个item就会调用几次此方法,然后返回一个view对象显示
// position:位置
// convertView:如果lv不能显示全部的数据,那么滚动后会把从显示到不显示的View传进来复用
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view;
if (convertView == null) {
view = getLayoutInflater().inflate(R.layout.simple_text, null);
} else {
view = convertView;
}
TextView tv = (TextView) view.findViewById(R.id.text1);
tv.setText(newList.get(position));
// 隔行变色,可以随心所欲
// if ((position & 1) == 1) {
// tv.setBackgroundResource(android.R.color.holo_green_light);
// } else {
// tv.setBackgroundResource(android.R.color.holo_red_light);
// }
return view;
}
}
// 自定义基础适配器
class MyAdapter extends BaseAdapter {
// listview显示的个数,如果有数据源有10条,而返回5,那么lv永远只能显示5条
// 所以最好就返回数据源的条数就好了
@Override
public int getCount() {
return data.size();
}
// 获取item绑定的数据时调用
@Override
public Object getItem(int position) {
Log.i(TAG, "position:" position);
return data.get(position);
}
// itemId
@Override
public long getItemId(int position) {
return position;
}
// lv显示几个item就会调用几次此方法,然后返回一个view对象显示
// position:位置
// convertView:如果lv不能显示全部的数据,那么滚动后会把从显示到不显示的View传进来复用
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view;
if (convertView == null) {
view = getLayoutInflater().inflate(R.layout.simple_text, null);
} else {
view = convertView;
}
TextView tv = (TextView) view.findViewById(R.id.text1);
tv.setText(data.get(position));
// 隔行变色,可以随心所欲
// if ((position & 1) == 1) {
// tv.setBackgroundResource(android.R.color.holo_green_light);
// } else {
// tv.setBackgroundResource(android.R.color.holo_red_light);
// }
return view;
}
}
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
Toast.makeText(
this,
"position:" position " item:"
parent.getItemAtPosition(position).toString(),
Toast.LENGTH_LONG).show();
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
// firstVisibleItem:第一个显示的item位置
// visibleItemCount:当前显示的item个数
// totalItemCount:listview的item总个数
scrollInfo.setText("first:" firstVisibleItem " visible:"
visibleItemCount " total:" totalItemCount);
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
switch (scrollState) {
// 手指接触屏幕滑动
case OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:
// 手指离开屏幕做惯性滑动
case OnScrollListener.SCROLL_STATE_FLING:
// 当滑动要最后一行时加载数据
if (view.getLastVisiblePosition() >= view.getCount() - 2) {
// 可以通过网络加载数据等。
// 判断是否还是在加载中
if (currentThread == null || !currentThread.isAlive()) {
// 添加listview尾部控件加载中
lv.addFooterView(footer, null, false);
// 启动线程加载数据
currentThread = new DataLoadThread();
currentThread.start();
}
}
break;
// 不滑动
case OnScrollListener.SCROLL_STATE_IDLE:
break;
}
}
}