因为我想使用“自定义列表适配器”,以便可以为列表设置样式,但“过滤器”功能无法正常工作.我可以使用基本的过滤功能,但是一旦过滤结果列表小于我开始过滤时显示的listItems数量,应用程序就会崩溃.
这段代码中还有第二个问题,我不确定是否相关,但是何时
明确();在publishResults中运行,然后应用程序也崩溃.
这是我正在使用的代码.
package com.android.example;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.Filter;
import android.widget.TextView;
public class CustomListAdapter extends ArrayAdapter<String> {
private Context mContext;
private String[] items;
private String[] filtered;
public CustomListAdapter(Context context, int textViewResourceId, String[] items) {
super(context, textViewResourceId, items);
this.filtered = items;
this.items = filtered;
setNotifyOnChange(true);
mContext = context;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View v = convertView;
if (v == null) {
LayoutInflater vi = (LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
v = vi.inflate(R.layout.list_item, null);
}
String o = filtered[position];
if (o != null) {
TextView tt = (TextView) v.findViewById(R.id.tvViewRow);
if (tt != null) {
tt.setText("Name: "+o);
}
}
return v;
}
public void notifyDataSetInvalidated()
{
super.notifyDataSetInvalidated();
}
private Filter filter;
public Filter getFilter()
{
if(filter == null)
filter = new NameFilter();
return filter;
}
private class NameFilter extends Filter
{
@Override
protected FilterResults performFiltering(CharSequence constraint) {
// NOTE: this function is *always* called from a background thread, and
// not the UI thread.
constraint = constraint.toString().toLowerCase();
FilterResults result = new FilterResults();
if(constraint != null && constraint.toString().length() > 0)
{
ArrayList<String> filt = new ArrayList<String>();
List<String> lItems = new ArrayList<String>();
synchronized (items)
{
lItems = Arrays.asList(items);
//Collections.copy(lItems, Arrays.asList(items));
}
for(int i = 0, l = lItems.size(); i < l; i++)
{
String m = lItems.get(i);
if(m.toLowerCase().startsWith(constraint.toString()))
filt.add(m);
}
result.count = filt.size();
result.values = filt.toArray(new String[0]);
}
else
{
synchronized(items)
{
result.values = items;
result.count = Arrays.asList(items).size();
}
}
return result;
}
@Override
protected void publishResults(CharSequence constraint, FilterResults results) {
// NOTE: this function is *always* called from the UI thread.
filtered = (String[])results.values;
notifyDataSetChanged();
clear();
notifyDataSetInvalidated();
}
}
}
解决方法:
我只是有同样的问题.只需将getCount()方法放在适配器类中即可.它应该返回过滤后的计数.像这样:
public int getCount() {
return mItems.size();
}
我过滤了mItems.