AutoCompleteTextView这个控件用于输入框的自动完成提示,非常适合搜索框等。它本质上是个EditText
,实际上它也是从EditText
继承的,使用起来也十分简单。
使用要点如下:
- 利用
ListAdapter
(一般使用ArrayAdapter
)为AutoCompleteTextView
提供数据,若有需要还可以重载getView()
以自定义列表项的显示方式。这一步同ListView
。 - 如果需要根据输入内容进行动态提示,那么adapter需要实现
Filterable
接口,重载getFilter()
函数实现提示算法。getFilter()
需返回Filter
对象,该对象包含至少两个方法:performFiltering()
在后台执行过滤,publishResults()
在UI线程执行,负责将过滤结果显示到列表中。还有第三个方法convertResultToString()
可以控制用户点击提示时要填充至输入框的文本内容。
示例代码大致如下。
AutoCompleteTextView autoComplete = new AutoCompleteTextView(context); autoComplete.setThreshold(2); // 设置最少几个字符触发自动完成 MyAdapter adapter = new MyAdapter(context); autoComplete.setAdapter(adapter); /** * Adapter定义 */ class MyAdapter extends ArrayAdapter<MyObject> implements Filterable{ @Override public View getView(int position, View convertView, ViewGroup parent) { // define your list item view here 在此处定义列表项的视图 } /** * 实现自动完成的过滤算法 */ @Override public Filter getFilter() { Filter filter = new Filter() { /** * 本方法在后台线程执行,定义过滤算法 */ @Override protected FilterResults performFiltering(CharSequence constraint) { String keyword = String.valueOf(constraint).toLowerCase(); // 此处实现过滤 // 过滤后利用FilterResults将过滤结果返回 FilterResults filterResults = new FilterResults(); filterResults.values = results; // results是上面的过滤结果 filterResults.count = results.size(); // 结果数量 return filterResults; } /** * 本方法在UI线程执行,用于更新自动完成列表 */ @Override protected void publishResults(CharSequence constraint, FilterResults results) { if (results != null && results.count > 0) { // 有过滤结果,显示自动完成列表 MyAdapter.this.clear(); // 清空旧列表 MyAdapter.this.addAll((List<MyObject>)results.values); notifiDataSetChanged(); } else { // 无过滤结果,关闭列表 notifyDataSetInvalidated(); } } /** * 如果需要控制提示文本的显示方式,重载此函数 */ @Override public CharSequence convertResultToString(Object resultValue) { MyObject obj = (MyObject) resultValue; return obj.name; } }; } }