android edittext+listview进阶 实现搜索listview中的内容 定制自己的过滤器

上一次直接使用的是arrayadapter 以及 系统自带的simple_list1布局文件.但是开发中,我们基本是不会用到那么简单的cell的,下面就来说说如何定制自己的过滤器,让他想搜索什么内容就搜索什么内容

效果图:

listview_cell布局:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/iv_logo"
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:src="@drawable/ic_launcher" />

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="50dp"
        android:orientation="vertical" >

        <TextView
            android:id="@+id/tv_name"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="name"
            android:layout_weight="1" />

        <TextView
            android:id="@+id/tv_show"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="我就是我不一样的烟火"
            android:layout_weight="1" />
    </LinearLayout>

</LinearLayout>

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"
    tools:context="com.example.testedittextlistview.MainActivity" >

    <include layout="@layout/myedittext" />

    <ListView
        android:id="@+id/lv_main"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#000" >
    </ListView>

</LinearLayout>

listview_adapter:

package com.example.testedittextlistview;

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

import android.content.Context;
import android.text.TextUtils;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Filter;
import android.widget.ImageView;
import android.widget.TextView;

public class MyListViewAdapter extends BaseAdapter {

	//这个是我们数据的总集合,在过滤的时候,这个应该是不变的
	private List<People> myforeverlist;
	//上下文菜单
	private Context context;

	//这个是,过滤的时候记载满足要求的那些数据的集合
	private List<People> mFilteredArrayList;
	//这个是,需要设置给adapter的
	private List<People> myPeopleList;

	public MyListViewAdapter(Context context, List<People> list) {
		this.context = context;
		this.myforeverlist = list;
		//这个时候把我们的一些中间变量给初始化一下
		mFilteredArrayList = new ArrayList<People>();
		myPeopleList = new ArrayList<People>();
		//把我们传递过来的数据,弄到这个集合里面.保存原始集合的完整性
		myPeopleList.addAll(myforeverlist);
	}

	@Override
	public int getCount() {
		return myPeopleList.size();
	}

	@Override
	public People getItem(int position) {
		return myPeopleList.get(position);
	}

	@Override
	public long getItemId(int position) {
		// TODO Auto-generated method stub
		return position;
	}

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		// TODO Auto-generated method stub
		if(convertView==null) {
			vHolder = new viewHolder();
			convertView = View.inflate(context, R.layout.listview_cell, null);
			vHolder.iv_logo = (ImageView) convertView.findViewById(R.id.iv_logo);
			vHolder.tv_name = (TextView) convertView.findViewById(R.id.tv_name);
			vHolder.tv_show = (TextView) convertView.findViewById(R.id.tv_show);
			convertView.setTag(vHolder);
		} else {
			vHolder = (viewHolder) convertView.getTag();
		}

//		vHolder.iv_logo.setImageResource(resId);
		vHolder.tv_name.setText(getItem(position).getName());
		vHolder.tv_show.setText(getItem(position).getShow());

		return convertView;
	}

	private viewHolder vHolder;
	class viewHolder{
		public ImageView iv_logo;
		public TextView tv_name;
		public TextView tv_show;
	}

	private NameFilter nameFilter;

	public NameFilter getFilter() {
		if(nameFilter==null) {
			nameFilter = new NameFilter();
		}

		return nameFilter;
	}

	// 过滤数据
	class NameFilter extends Filter {

		// 执行筛选
		@Override
		protected FilterResults performFiltering(CharSequence charSequence) {
			FilterResults filterResults = new FilterResults();

			if (TextUtils.isEmpty(charSequence)) {
				mFilteredArrayList.clear();// 清除一下
				filterResults.values = myforeverlist;
				return filterResults;
			} else {
				mFilteredArrayList.clear();// 清除一下
				for (Iterator<People> iterator = myforeverlist.iterator(); iterator
						.hasNext();) {
					People name = iterator.next();
					if (name.getName().contains(charSequence)) {
						mFilteredArrayList.add(name);
					}
				}
				filterResults.values = mFilteredArrayList;
				return filterResults;
			}

		}

		// 筛选结果
		@Override
		protected void publishResults(CharSequence arg0, FilterResults results) {
			myPeopleList = (ArrayList<People>) results.values;
			if (results.count > 0) {
				notifyDataSetChanged();
			} else {
				notifyDataSetInvalidated();
			}
		}
	}

}

activity_main.java:

package com.example.testedittextlistview;

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

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.WindowManager;
import android.view.View.OnClickListener;
import android.view.inputmethod.InputMethodManager;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.ListView;
import android.widget.Toast;

public class MainActivity extends Activity {

	private EditText query;
	private ImageButton search_clear;
	private ListView lv_main;

	//控制输入框显示隐藏的代码
	private InputMethodManager inputMethodManager;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		initView();
	}

	private void initView() {
		inputMethodManager=  (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);

		query = (EditText) findViewById(R.id.query);
		search_clear = (ImageButton) findViewById(R.id.search_clear);

		search_clear.setOnClickListener(new OnClickListener() {
			@Override
			public void onClick(View v) {//点击一下清空内容咯
				query.getText().clear();
				hideSoftKeyboard();//隐藏键盘
			}
		});

		//listview初始化控件并丰富一些内容
		lv_main = (ListView) findViewById(R.id.lv_main);
		List<People> list = new ArrayList<People>();
		for(int i=1;i<10;i++) {
			People tPeople = new People();
			if(i<4) {//让内容稍微不一样点
				tPeople.setName("Test"+i);
				tPeople.setShow("今夜不回家"+i);
			} else {
				tPeople.setName("HAHA"+i);
				tPeople.setShow("Love tonight"+i);
			}

			list.add(tPeople);
		}

		final MyListViewAdapter adapter = new MyListViewAdapter(getApplicationContext(), list);
		lv_main.setAdapter(adapter);

		// 为listview添加点击事件
		lv_main.setOnItemClickListener(new OnItemClickListener() {
			@Override
			public void onItemClick(AdapterView<?> parent, View view,
					int position, long id) {
				// 这里注意使用的是adapter.getItem(position)
				// ,而不是myString[position],如果使用第二种的话,效果很坑哟
				Toast.makeText(getApplicationContext(),
						"点击了" + adapter.getItem(position).getName(), Toast.LENGTH_SHORT)
						.show();
			}
		});

		// 为edittext添加内容改变的监听,onTextChanged 里面让adapter,设置过滤的条件
		query.addTextChangedListener(new TextWatcher() {
			@Override
			public void onTextChanged(CharSequence s, int start, int before,
					int count) {
				adapter.getFilter().filter(s);
				if(s.length()>0) {
					 search_clear.setVisibility(View.VISIBLE);
				} else {
					search_clear.setVisibility(View.GONE);
				}
			}

			// 下面两个方法可以直接无视
			@Override
			public void beforeTextChanged(CharSequence s, int start, int count,
					int after) {
			}
			@Override
			public void afterTextChanged(Editable s) {
			}
		});
	}

	/**
	 * 隐藏输入法的示例代码
	 */
	void hideSoftKeyboard() {
		if (getWindow().getAttributes().softInputMode != WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN) {
			if (getCurrentFocus() != null)
				inputMethodManager.hideSoftInputFromWindow(getCurrentFocus().getWindowToken(),
						InputMethodManager.HIDE_NOT_ALWAYS);
		}
	}

}

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-12 23:57:11

android edittext+listview进阶 实现搜索listview中的内容 定制自己的过滤器的相关文章

android EditText控件如何禁止输入内容

问题? android EditText控件如何禁止往里面输入内容? 修改版解决方法: EditText editText =  (EditText) findViewById(R.id.editText1); editText.setKeyListener(null); 看到这个问题大家可能有点奇怪了,EditText的功能不就是往上面写入内容吗? 再者,如果真要禁止输入文本,在布局文件中添加 android:focusable="false", 或者在代码中使用editText.s

android edittext + listview 实现搜索listview中的内容

以前一直以为edittext中输入一些东西.然后可以检测listview中的内容很高大上.一直没有去尝试.现在项目中遇到了.特此过来尝试一番.结果发现挺简单的,效果还不错,主要就是用到了edittext的 textchange监听 以及listview的过滤.下面直接上截图: xml: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://

【Android进阶】关于ListView中item与控件抢夺焦点的那些事

在开发中,listview可以说是我们使用最频繁的控件之一了,但是关于listview的各种问题也是很多.当我们使用自定义布局的Listview的时候,如果在item的布局文件里面存在Button或者是CheckBox等控件以及其子类控件的时候,经常会碰到各种控件的点击事件冲突的情况,那么我们如何来处理Listview中这种控件之间焦点冲突的情况呢? 我们以item存在一个Button控件为例 首先,加入我们不设置任何关于焦点的属性,比如focus等,代码如下 @Override public

android UI进阶之实现listview中checkbox的多选与记录

今天继续和大家分享涉及到listview的内容.在很多时候,我们会用到listview和checkbox配合来提供给用户一些选择操作.比如在一个清单页面,我们需要记录用户勾选了哪些条目.这个的实现并不太难,但是有很多朋友来问我如何实现,他们有遇到各种各样的问题,这里就一并写出来和大家一起分享. ListView的操作就一定会涉及到item和Adapter,我们还是先来实现这部分内容. 首先,写个item的xml布局,里面放置一个TextView和一个CheckBox.要注意的时候,这里我设置了C

android UI进阶之实现listview的分页加载

 分享了下拉刷新,这是一个用户体验非常好的操作方式.新浪微薄就是使用这种方式的典型. 还有个问题,当用户从网络上读取微薄的时候,如果一下子全部加载用户未读的微薄这将耗费比较长的时间,造成不好的用户体验,同时一屏的内容也不足以显示如此多的内容.这时候,我们就需要用到另一个功能,那就是listview的分页了.通过分页分次加载数据,用户看多少就去加载多少. 通常这也分为两种方式,一种是设置一个按钮,用户点击即加载.另一种是当用户滑动到底部时自动加载.今天我就和大家分享一下这个功能的实现. 首先,

android ListView进阶

ListView 1.在android 开发中很多时候都要用到ListView的这个控件的,但用这个控件的时候会遇到一些问题,如在ListView中有Button按钮,就需要将按钮的监听事件给分离出来,且将Button该为自己的定义的Button控件 这只是一个思路,在进行例子之前,对一些小的知识点进行一下复习: 2.API是开发中最好的老师,它对ListView的解释是: 3.这里就对ListView运行机制做个解释(引用别人的一段话): listView在开始绘制的时候,系统首先调用getC

Android实战技巧:如何在ScrollView中嵌套ListView

前几天因为项目的需要,要在一个ListView中放入另一个ListView,也即在一个ListView的每个ListItem中放入另外一个ListView.但刚开始的时候,会发现放入的小ListView会显示不完全,它的高度始终有问题.上网查了下,发现别人也有遇到这样的问题,而大多数人都不推荐这样的设计,因为默认情况下Android是禁止在ScrollView中放入另外的ScrollView的,它的高度是无法计算的. 又搜索了一下,发现有StackOverflow上的牛人已经解决了这个问题,经过

android 自定义adapter和线程结合 + ListView中按钮滑动后状态丢失解决办法

adapter+线程 1.很多时候自定义adapter的数据都是来源于服务器的,所以在获取服务器的时候就需要异步获取,这里就需要开线程了(线程池)去获取服务器的数据了.但这样有的时候adapter的中没有数据. 如下面的代码: 这就是在initData中异步获取服务器的数据,然后实例化adatper,再将adapter赋给listView. 2.initData()中的代码是: 这里线程要睡眠5秒钟,是为了模仿网络的耗时操作 3.Handler: 在Handler中接收到数据后给list赋值后,

Android新浪微博客户端(七)——ListView中的图片异步加载、缓存

原文出自:方杰|http://fangjie.sinaapp.com/?p=193转载请注明出处 最终效果演示:http://fangjie.sinaapp.com/?page_id=54该项目代码已经放到github:https://github.com/JayFang1993/SinaWeibo 一.ListView的图片异步加载 我们都知道对每一个Weibo Item都有用户头像,而且每一条微博还可能带有图片.如果在加载列表的同时加载图片,这样有几个缺点,第一很费事,界面卡住,用户体验很不