当前位置: 首页 > 知识库问答 >
问题:

android中ArrayAdapter的扩展

姬存
2023-03-14

我需要重写类ArrayAdapter中的getFilter()方法,我在github中找到了源代码

//package name

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import android.content.Context;
import android.util.Log;
import android.widget.ArrayAdapter;
import android.widget.Filter;
import android.widget.Filterable;

public class CustomAdapter<T> extends ArrayAdapter<T> implements Filterable{

    private ArrayList<T> mOriginalValues;
    private List<T> mObjects;
    private CustomFilter mFilter;
    private final Object mLock = new Object();
    public CustomAdapter(Context context, int textViewResourceId, T[] objects) {
        super(context, textViewResourceId, objects);

        mObjects = Arrays.asList(objects);
        // TODO Auto-generated constructor stub
    }

    @Override
    public Filter getFilter() {
        // TODO Auto-generated method stub
        if (mFilter == null) {
            mFilter = new CustomFilter();
        }
        return mFilter;
    }


    private class CustomFilter extends Filter {
        @Override
        protected FilterResults performFiltering(CharSequence prefix) {
            FilterResults results = new FilterResults();
            Log.d("bajji", "its ---> " + prefix);
            if (mOriginalValues == null) {
                synchronized (mLock) {
                    mOriginalValues = new ArrayList<T>(mObjects);
                }
            }

            if (prefix == null || prefix.length() == 0) {
                ArrayList<T> list;
                synchronized (mLock) {
                    list = new ArrayList<T>(mOriginalValues);
                }
                results.values = list;
                results.count = list.size();
            } else {
                String prefixString = prefix.toString().toLowerCase();

                ArrayList<T> values;
                synchronized (mLock) {
                    values = new ArrayList<T>(mOriginalValues);
                }

                final int count = values.size();
                final ArrayList<T> newValues = new ArrayList<T>();
                final ArrayList<T> approxValues = new ArrayList<T>();
                final ArrayList<T> secondApproxValues = new ArrayList<T>();


                for (int i = 0; i < count; i++) {
                    final T value = values.get(i);
                    final String valueText = value.toString().toLowerCase();
                    boolean flag = true;
                    // First match against the whole, non-splitted value
                    if (valueText.startsWith(prefixString)) {
                        newValues.add(value);
                        flag = false;
                    } else {
                        final String[] words = valueText.split(" ");
                        final int wordCount = words.length;

                        // Start at index 0, in case valueText starts with space(s)
                        for (int k = 0; k < wordCount; k++) {
                            if (words[k].startsWith(prefixString)) {
                                newValues.add(value);
                                flag = false;
                                break;
                            } 
                        }
                    }

                    if(flag) {
                        if(approxMatch(valueText, prefixString) <= 3) { //change the stuff and do a levi work
                            approxValues.add(value);
                        }
                        else {
                            final String[] words = valueText.split(" ");
                            final int wordCount = words.length;

                            // Start at index 0, in case valueText starts with space(s)
                            for (int k = 0; k < wordCount; k++) {
                                if(approxMatch(words[k], prefixString) <= 3) {
                                    //leve work
                                    secondApproxValues.add(value);
                                    break;
                                }
                            }
                        }
                    }
                }
                newValues.addAll(approxValues);
                newValues.addAll(secondApproxValues);
                results.values = newValues;
                results.count = newValues.size();
            }
            return results;
        }
        @Override
        protected void publishResults(CharSequence constraint, FilterResults results) {
            //noinspection unchecked
            mObjects = (List<T>) results.values;
            if (results.count > 0) {
                notifyDataSetChanged();
            } else {
                notifyDataSetInvalidated();
            }
        }
    }

    private int approxMatch (String s, String t) {
          // an approxmimate string matching algo
          return p;
    }
}

问题是getFilter方法有一个私有内部类ArrayFilterhtml" target="_blank">对象,它有一个方法peFormFiltering,我需要在那里放一个不同的代码,所以我必须覆盖这个类。方法中有一个异常。

在扩展ArrayAdapter的派生类中,我创建了一个类似于ArrayFilter的私有内部类,并将其称为MyFilter,并且在方法PerformFiltering中再次得到相同的异常。

我找到了解决我问题的办法。我复制了ArrayAdapter类中的所有代码,并创建了一个名为MyAdapter的新类,并且修改了内部类ArrayFilter中的一些代码,使应用程序按照我希望的方式工作。但我觉得这不是最好的解决办法。

Android有不同的api级别,所以如果数组适配器在不同的api级别被更改,那么我必须在代码中添加这些更改。所以我觉得最好的方法是扩展类arrayadapter来创建myadapter而不是仅仅从arrayadapter中复制和粘贴代码

如何覆盖父类的内部私有类?

编辑2:现在我在问题中添加了完整的代码。如果我复制和编辑数组适配器,它就会工作得很好…问题只是当我延伸..!!现在代码和搜索工作很好。我用log.I进行了检查。但UI中的“自动完成建议”下拉列表不工作。我只得到我键入的第一个字符,下一个字符过滤发生,但UI更新没有发生。

共有1个答案

韦志新
2023-03-14

在stackoverflow社区提供了一些帮助后,我删除了该异常,后来发现返回的建议并没有真正改变,因为mobjects是从超类或基类返回的。问题是有两个公共方法getCount()getItem(int position)从基类中获取计数并从mObjects中获取列表。所以我只需要在我的类中添加这两个方法

public int getCount() {
    return mObjects.size();
}

public T getItem(int position) {
    return mObjects.get(position);
}

现在将返回派生类的mobjects。在UI中的下拉列表中更新。

我不是java专家,但这解决了我的问题。如果您有任何建议,使代码更好,请添加在评论或随时编辑答案!!

 类似资料:
  • 不管怎样,关于我的问题:有人愿意编写一个非常、非常、非常、通用、直接和简单的自定义ArrayAdapter,该ArrayAdapter需要两个字符串值,可以与ListView一起使用吗?…或者,尝试调试我的尝试,希望找到我的问题所在。 任何帮助都很感激,谢谢。 我已经包括了我知道需要的代码,但我一直在与其他所有东西罢工。 错误:(20,9)错误:没有为ArrayAdapter找到合适的构造函数(上

  • 在自定义arrayAdapter中实现自定义getFilter时遇到问题。实际上,我不知道如何实现它。尝试了各种代码,但仍然没有成功。这是我的自定义阵列适配器。 这是ListTO课程。 这是布局图。 这里的搜索关键字来自“inputSearch”编辑文本。 这是文本更改的侦听器。 谢谢

  • 我正在尝试将ArrayList中的一个值放入我的listView,下面是详细信息。 这是ArrayList信息的示例: 我想从用户ArrayList中获取州数据,例如,我只想获取“新墨西哥州”、“亚利桑那州”、“亚利桑那州”和“加利福尼亚州”的数据,并将其显示在我的listView中 如果可能的话,我还想删除副本并按升序排序 下面是我的代码 我知道我不应该在arrayAdapter中使用state

  • 本文向大家介绍Android中GridView和ArrayAdapter用法实例分析,包括了Android中GridView和ArrayAdapter用法实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了Android中GridView和ArrayAdapter用法。分享给大家供大家参考,具体如下: GridView是一个表格化的二维排版的View,当GridView的文字放不下时会

  • 问题内容: 实例化ArrayAdapter时,我收到以下警告(编译正常): 这是问题所在: 有人对它为什么给我这个警告有任何想法吗? 问题答案: 这是因为希望您指定它将处理的对象类型。因此,为了避免这些警告,请执行以下操作:

  • 问题内容: 我有一个要与一起使用以添加不同样式的行的。这些行是在我的应用程序中的不同状态下创建的,并且应根据不同状态对行进行样式设置(例如颜色和填充物)。 这是一些伪代码: 创建时: 在不同的状态下(由另一个线程使用MessageHandler触发),在包含消息的列表中添加一行: 效果很好,根据状态不同,消息会在列表中弹出,但是我想让行的样式不同。这该怎么做?使用自定义的Add()方法创建自定义的