主要原理:是在主界面有两个空间,一个是EditText,一个是ListView,ListView是放在EditText下面的,然后自定义建立一个adapter适配器,
这个适配器要继承Filterable这个接口,并实现这个接口的两个方法,一个是过滤方法,一个是过滤后的方法,一般我们是在过滤方法里面实现过滤,
在过滤后的方法里面调用notifyDataSetChanged();也就是使适配器更新数据,这里还有用到一个pinyin4j-2.5.0.jar的架包,这个主要是汉字转拼
音的功能
MainActivity.Java
public class MainActivity extends Activity { private EditText et_filter; private UserAdapter adapter; private ListView lv_list; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); List<UserInfo> userInfos = new ArrayList<UserInfo>(); for (int i = 0; i < 2; i++) { UserInfo user = new UserInfo(); user.setUsername("张三" + i); user.setPhonenum("12345" + i); userInfos.add(user); } for (int i = 0; i < 2; i++) { UserInfo user = new UserInfo(); user.setUsername("李四" + i); user.setPhonenum("12345" + i); userInfos.add(user); } lv_list = (ListView) findViewById(R.id.lv_list); adapter = new UserAdapter(MainActivity.this, userInfos); lv_list.setAdapter(adapter); et_filter = (EditText) findViewById(R.id.et_filter); et_filter.addTextChangedListener(new TextWatcher() { @Override public void onTextChanged(CharSequence s, int start, int before, int count) { adapter.getFilter().filter(et_filter.getText().toString()); } @Override public void beforeTextChanged(CharSequence s, int start, int count, int after) { } @Override public void afterTextChanged(Editable s) { } }); } }
UserAdapter.java
package com.example.edittextfilterdemo; import java.util.ArrayList; import java.util.List; import android.content.Context; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Filter; import android.widget.Filterable; import android.widget.TextView; /** * 自定义具有过滤功能的adapter类 * */ public class UserAdapter extends BaseAdapter implements Filterable { private MyFilter myFilter; private List<UserInfo> userInfos; private Context context; private ArrayList<UserInfo> mOriginalValues; private final Object mLock = new Object(); public UserAdapter(Context context, List<UserInfo> userInfos) { this.context = context; this.userInfos = userInfos; } @Override public int getCount() { // TODO Auto-generated method stub return userInfos.size(); } @Override public Object getItem(int arg0) { // TODO Auto-generated method stub return userInfos.get(arg0); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { View view = convertView; ViewHolder holder; if (view == null) { view = LayoutInflater.from(context).inflate(R.layout.list_item, null); holder = new ViewHolder(); holder.tv_nick = (TextView) view.findViewById(R.id.tv_nick); holder.tv_mobile = (TextView) view.findViewById(R.id.tv_mobile); view.setTag(holder); } else { holder = (ViewHolder) view.getTag(); } holder.tv_nick.setText(userInfos.get(position).getUsername()); holder.tv_mobile.setText(userInfos.get(position).getPhonenum()); return view; } static class ViewHolder { TextView tv_nick; TextView tv_mobile; } @Override public Filter getFilter() { if (myFilter == null) { myFilter = new MyFilter(); } return myFilter; } class MyFilter extends Filter { @Override protected FilterResults performFiltering(CharSequence prefix) { // 持有过滤操作完成之后的数据。该数据包括过滤操作之后的数据的值以及数量。 count:数量 values包含过滤操作之后的数据的值 FilterResults results = new FilterResults(); if (mOriginalValues == null) { synchronized (mLock) { // 将list的用户 集合转换给这个原始数据的ArrayList mOriginalValues = new ArrayList<UserInfo>(userInfos); } } if (prefix == null || prefix.length() == 0) { synchronized (mLock) { ArrayList<UserInfo> list = new ArrayList<UserInfo>( mOriginalValues); results.values = list; results.count = list.size(); } } else { // 做正式的筛选 String prefixString = prefix.toString().toLowerCase(); // 声明一个临时的集合对象 将原始数据赋给这个临时变量 final ArrayList<UserInfo> values = mOriginalValues; final int count = values.size(); // 新的集合对象 final ArrayList<UserInfo> newValues = new ArrayList<UserInfo>( count); for (int i = 0; i < count; i++) { // 如果姓名的前缀相符或者电话相符就添加到新的集合 final UserInfo value = (UserInfo) values.get(i); Log.i("coder", "PinyinUtils.getAlpha(value.getUsername())" + PinyinUtils.getFirstSpell(value.getUsername())); if (PinyinUtils.getFirstSpell(value.getUsername()).startsWith( prefixString) || value.getPhonenum().startsWith(prefixString)||value.getUsername().startsWith(prefixString)) { newValues.add(value); } } // 然后将这个新的集合数据赋给FilterResults对象 results.values = newValues; results.count = newValues.size(); } return results; } @Override protected void publishResults(CharSequence constraint, FilterResults results) { // 重新将与适配器相关联的List重赋值一下 userInfos = (List<UserInfo>) results.values; if (results.count > 0) { notifyDataSetChanged(); } else { notifyDataSetInvalidated(); } } } }
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.edittextfilterdemo.MainActivity" > <EditText android:id="@+id/et_filter" android:layout_width="match_parent" android:layout_height="wrap_content" /> <ListView android:id="@+id/lv_list" android:layout_width="match_parent" android:layout_height="wrap_content" > </ListView> </LinearLayout>
以上这篇edittext + listview 实现搜索listview中的内容方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
问题内容: 在我的项目中,我必须向用户显示一个ListView,它基本上包含EditText。 就像问卷一样,当他回答问题时,他可以下去回答下一个问题。(然后返回) 我不知道为什么,但是用户进入ListView,内容未保存,并显示一些特殊值,如其他EditText。我没有找到纠正该行为的方法,这真的很着急。 基本上,我做了一个TextWatcher,将数据注册到数据库中,还注册到了包含所有值的临时
本文向大家介绍ListView实现顶部和底部内容指示器的方法,包括了ListView实现顶部和底部内容指示器的方法的使用技巧和注意事项,需要的朋友参考一下 顶部指示器? 这是什么? 好吧,我承认这是我自己想出来的词,因为我不知道它有什么学名,究竟是什么呢?看下这个图就知道了。 这是我们的美工MM画的,偶的神呐,这虽然很漂亮,不过也让人头疼,这个箭头应该在滚到顶部的时候消失,滚下来的时候(即有条目隐
本文向大家介绍Android编程实现ListView内容无限循环显示的方法,包括了Android编程实现ListView内容无限循环显示的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android编程实现ListView内容无限循环显示的方法。分享给大家供大家参考,具体如下: 其实要达到无限循环显示,主要就是实现继承Adapter的类。 我这里用到的是BaseAdapter 在on
本文向大家介绍Android 根据EditText搜索框ListView动态显示数据,包括了Android 根据EditText搜索框ListView动态显示数据的使用技巧和注意事项,需要的朋友参考一下 根据EditText搜索框ListView动态显示数据是根据需求来的,觉得这之中涉及的东西可能比较的有意思,所以动手来写一写,希望对大家有点帮助。 首先,我们来分析下整个过程: 1、建立一个lay
本文向大家介绍Android中实现长按修改ListView对象的内容,包括了Android中实现长按修改ListView对象的内容的使用技巧和注意事项,需要的朋友参考一下 实现的效果如下: 我在ListView的Item长按事件内打开一个弹出窗口,窗口内有一个EditText对象,在这个编辑框内输入文本点确定后,直接修改掉ListView对象内某个TextView对象的内容。 示例代码如下: 总结
本文向大家介绍Android中ListView下拉刷新的实现方法,包括了Android中ListView下拉刷新的实现方法的使用技巧和注意事项,需要的朋友参考一下 ListView中的下拉刷新是非常常见的,也是经常使用的,看到有很多同学想要,那我就整理一下,供大家参考。那我就不解释,直接上代码了。 这里需要自己重写一下ListView,重写代码如下: 重写完ListView之后,在布局文件中是这么