AndroidでRecyclerViewアダプターのフィルターメソッドを最適化しようとしています。リストはArrayListとして使用されます。私はこれを見たpostしかし、彼らは元のリストから毎回フィルタリングされています。Android Recyclerビューアダプターフィルター(アニメーションあり)
例:文字列 'a'の結果が「m」の場合、「am」の結果は「a」結果のサブセットです(results.size()< = 10)。
この質問では3つの点があります。
- ArrayMapを使用してHashMapメモリを最適化することはできますか? Integerオブジェクト配列の代わりにStringのコンマ区切り位置を使うべきか、またはintプリミティブ配列を使う方法はありますか?
- 私はこの結果でアニメーションを取得していません、それを取得する方法は? (私は
notifyItemInserted
まだアニメーションを使用していません) - 2文字まで、または結果リストのサイズに応じて、データをHashmapに保存する必要がありますか?
以下のコードでは、mListがonBindViewHolder
メソッドで使用されています。 copyListには常にすべてのデータが含まれます(挿入も削除も行われません)。
class MyFilter extends Filter {
/**
* 1. check do we have search results available (check map has this key)
* 2. if available, remove all rows and add only those which are value for that key (string)
* 3. else check do we have any key available starting like this, s=har, already available -ha then it can be reused
*
* @param constraint
*/
@Override
protected FilterResults performFiltering(CharSequence constraint) {
//Here you have to implement filtering way
final FilterResults results = new FilterResults();
if (!mSearchMap.containsKey(constraint.toString())) {
String supersetKey = getSupersetIfAvailable(mSearchMap, constraint.toString());
if (supersetKey == null) {
List<Integer> foundPositions = doFullSearch(copyList, constraint.toString());
mSearchMap.put(constraint.toString(), foundPositions);
} else {
List<Integer> foundPositions = filterFromSuperset(copyList, mSearchMap.get(supersetKey), constraint.toString());
mSearchMap.put(constraint.toString(), foundPositions);
}
}
return results;
}
private String getSupersetIfAvailable(Map<String, List<Integer>> mSearchMap, String s) {
Set<String> set = mSearchMap.keySet();
List<String> list = new ArrayList<>(set);
Collections.sort(list);
Collections.reverse(list);
for (String c : list) {
if (s.startsWith(c)) {
return c;
}
}
return null;
}
private List<Integer> filterFromSuperset(List<WeekWorkBean> list, List<Integer> supersetResults, String s) {
List<Integer> results = new ArrayList<>();
String lowerS = s.toLowerCase();
for (int i = 0; i < supersetResults.size(); i++) {
if (list.get(supersetResults.get(i)).getEmpName().toLowerCase().startsWith(lowerS)) {
results.add(supersetResults.get(i));
}
}
return results;
}
private List<Integer> doFullSearch(List<WeekWorkBean> list, String s) {
List<Integer> results = new ArrayList<>();
for (int i = 0; i < list.size(); i++) {
if (list.get(i).getEmpName().toLowerCase().startsWith(s.toLowerCase())) {
results.add(i);
}
}
return results;
}
@Override
protected void publishResults(CharSequence constraint, FilterResults results) {
// here you can use result - (f.e. set in in adapter list)
mList.clear();
notifyDataSetChanged();
List<Integer> res = mSearchMap.get(constraint.toString());
int j = 0;
for (Integer i : res) {
mList.add(copyList.get(i));
notifyItemInserted(j++);
}
}
}
は私の答えをチェックし、DiffUtils私はHashMapのメモリはArrayMapを使用することによって最適化することができ、あなたが –
、これら2点を探しているものでしょうか? Integerオブジェクト配列の代わりにStringのコンマ区切り位置を使うべきか、またはintプリミティブ配列を使う方法はありますか? ハッシュマップに保持するデータ量は2文字までか、結果リストのサイズに従うべきですか? –
@wojciech_maciejewskiあなたの答えは有用で、私はupvoteを与えました。それは完全な質問に答えるものではありません –