gpt4 book ai didi

android - 过滤时自定义 ArrayAdapter 未更新

转载 作者:行者123 更新时间:2023-11-29 21:59:22 25 4
gpt4 key购买 nike

我已经从 this tutorial 实现了一个 CustomArrayAdapter ListView 的每个条目都有一个缩略图和 2 行。除了过滤之外,它工作得很好。我一直在尝试执行 this 之后的过滤, thisthis问题, 但 ListView 永远不会更新。

这是我的多行布局代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="?android:attr/listPreferredItemHeight"
android:padding="6dip">

<ImageView
android:id="@+id/thumb"
android:background="@drawable/thumb"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_marginRight="6dip"
android:layout_marginTop="2dip"
android:layout_marginBottom="2dip"/>

<LinearLayout
android:orientation="vertical"
android:layout_width="0dip"
android:layout_weight="1"
android:layout_height="fill_parent">

<TextView
android:id="@+id/custom_title"
android:layout_width="fill_parent"
android:layout_height="0dip"
android:layout_weight="1"
android:textColor="@color/black"
android:gravity="center_vertical"
/>

<TextView
android:id="@+id/desc"
android:layout_width="fill_parent"
android:layout_height="0dip"
android:layout_weight="1"
android:textColor="@color/darkgray"
android:textStyle="italic"
android:singleLine="true"
android:ellipsize="marquee"
/>

</LinearLayout>

这是我的 customListAdapter 代码(在 first link 之后)

public class CustomListAdapter extends ArrayAdapter implements Filterable{

private static ArrayList<CustomListItem> searchArrayList;
private static ArrayList<CustomListItem> subItems;
private PTypeFilter filter;


private LayoutInflater mInflater;

public CustomListAdapter(Context context, int textViewResourceId, ArrayList<CustomListItem> results) {
super(context,textViewResourceId, results);
searchArrayList = results;
mInflater = LayoutInflater.from(context);
}
public int getCount() {
return searchArrayList.size();
}

public Object getItem(int position) {
return searchArrayList.get(position);
}

public long getItemId(int position) {
return position;
}

public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.custom_row, null);
holder = new ViewHolder();
holder.txtTitle = (TextView) convertView.findViewById(R.id.custom_title);
holder.txtDesc = (TextView) convertView.findViewById(R.id.desc);
holder.thumb = (ImageView) convertView.findViewById(R.id.thumb);

convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}

holder.txtTitle.setText(searchArrayList.get(position).getTitle());
holder.txtDesc.setText(searchArrayList.get(position).getDesc());
holder.thumb.setImageBitmap(searchArrayList.get(position).getThumb());
//holder.thumb.setBackgroundColor(Color.BLACK);

return convertView;
}

static class ViewHolder {
TextView txtTitle;
TextView txtDesc;
ImageView thumb;
}

@Override
public Filter getFilter() {
Log.i("CustomListAdapter", "testing filter");
if (filter == null){
filter = new PTypeFilter();
}
return filter;
}

private class PTypeFilter extends Filter{


@SuppressWarnings("unchecked")
@Override
protected void publishResults(CharSequence prefix,
FilterResults results) {
// NOTE: this function is *always* called from the UI thread.
subItems = (ArrayList<CustomListItem>)results.values;

notifyDataSetChanged();
}

@SuppressWarnings("unchecked")
protected FilterResults performFiltering(CharSequence prefix) {
// NOTE: this function is *always* called from a background thread, and
// not the UI thread.

FilterResults results = new FilterResults();
ArrayList<CustomListItem> i = new ArrayList<CustomListItem>();

if (prefix!= null && prefix.toString().length() > 0) {

for (int index = 0; index < searchArrayList.size(); index++) {
CustomListItem si = searchArrayList.get(index);
if(si.toString().compareTo(prefix.toString()) == 0){
i.add(si);
}
}
results.values = i;
results.count = i.size();
}
else{
synchronized (searchArrayList){
results.values = searchArrayList;
results.count = searchArrayList.size();
}
}

return results;
}
}
}

在我的主要 Activity 中,我这样调用自定义基础适配器:

adapter = new CustomListAdapter(this, R.id.custom_title, DATA);
setListAdapter(adapter);

(不是 100% 确定 R.id.custom_title 是我应该放在那里的 id。

我添加了调试消息,并且正在调用 TextChange,作为 getFilter() 方法。所以我不知道我做错了什么。在我从 ListAdapter 切换到 CustomListAdapter 之前,过滤工作正常:(

谢谢你的帮助

最佳答案

ListView 未被过滤,因为您在 subItems 上设置了过滤结果,而适配器类中未使用该过滤结果,因此调用 notifyDataSetChanged 将不起作用,因为从适配器的角度来看数据是完整的。您使用另一个列表来保存旧值是正确的,它们将是必需的,因此您拥有所有旧值。要解决问题,请添加行:

subItems = new ArrayList<CustomListItem>(searchArrayList);

在适配器的构造函数中,这是为了让您拥有完整值的副本以备后用。然后在 publishResults 方法中使用 searchArrayList 列表,因为这是支持适配器的列表:

searchArrayList =  (ArrayList<CustomListItem>)results.values;
notifyDataSetChanged();

然后在performFiltering方法中:

  if (prefix!= null && prefix.toString().length() > 0) {
// use the initial values !!!
for (int index = 0; index < subItems.size(); index++) {
CustomListItem si = subItems.get(index);
final int length = prefix.length();
// if you compare the Strings like you did it will never work as you compare the full item string(you'll have a match only when you write the EXACT word)
// keep in mind that you take in consideration capital letters!
if(si.toString().substring(0, prefixLength).compareTo(prefix.toString()) == 0){
i.add(si);
}
}
results.values = i;
results.count = i.size();
}
else{
// revert to the old values
synchronized (searchArrayList){
results.values = subItems;
results.count = subItems.size();
}
}

我希望它有用。

(not 100% sure that R.id.custom_title is the id I should be putting there.

没关系,因为您使用自己的自定义适配器。

关于android - 过滤时自定义 ArrayAdapter 未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12362158/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com