2015-11-19 61 views
0

我一直試圖將SearchView添加到我的RecyclerView一段時間,並引用了這些帖子hereherehere。在這一點上,我相信答案正在我的臉上。SearchView與RecyclerView

但是,我不知道如何實現時,例如,使用搜索查看以下內容:

private static final List<DataModel> getDummyData(){ 
    List<DataModel> dummyDataList = new ArrayList<>(); 

    dummyDataList.add(new DataModel("Alphabet", "Sub Alphabet")); 
    dummyDataList.add(new DataModel("Banana", "Sub Banana")); 
    dummyDataList.add(new DataModel("Captain", "Sub Captain")); 
    dummyDataList.add(new DataModel("Donut", "Sub Donut")); 
    dummyDataList.add(new DataModel("Elephant", "Sub Elephant")); 
    dummyDataList.add(new DataModel("Fox", "Sub Fox")); 
    dummyDataList.add(new DataModel("Giraffe", "Sub Giraffe")); 
    dummyDataList.add(new DataModel("Hippo", "Sub Hippo")); 
    dummyDataList.add(new DataModel("Iguana", "Sub Iguana")); 
    dummyDataList.add(new DataModel("Jumanji", "Sub Jumanji")); 

    return dummyDataList; 
    } 

這裏是我的當前設置(following this tutorial),使用Locale.getISOCountries();並搜索國家的名稱。

MainActivityFragment:

public class MainActivityFragment extends Fragment implements SearchView.OnQueryTextListener { 

private RecyclerView mRecyclerView; 
private List<DataModel> mDataModel; 
private RVAdapter adapter; 

public MainActivityFragment() { 
} 
@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
         Bundle savedInstanceState) { 
    View view = inflater.inflate(R.layout.tab_one_fragment, container, false); 

    mRecyclerView = (RecyclerView)view.findViewById(R.id.recyclerview); 
    LinearLayoutManager layoutManager = new LinearLayoutManager(getActivity()); 
    mRecyclerView.setLayoutManager(layoutManager); 
    return view; 
} 

@Override 
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 
    super.onViewCreated(view, savedInstanceState); 

    setHasOptionsMenu(true); 

    String[] locales = Locale.getISOCountries(); 

    mDataModel = new ArrayList<>(); 

    for (String countryCode : locales){ 
     Locale obj = new Locale("", countryCode); 
     mDataModel.add(new DataModel(obj.getDisplayCountry(), obj.getISO3Country())); 
    } 
    adapter = new RVAdapter(mDataModel); 
    mRecyclerView.setAdapter(adapter); 
} 
@Override 
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { 
    inflater.inflate(R.menu.menu_main, menu); 

    final MenuItem item = menu.findItem(R.id.action_search); 
    final SearchView searchView = (SearchView) MenuItemCompat.getActionView(item); 
    searchView.setOnQueryTextListener(this); 

    MenuItemCompat.setOnActionExpandListener(item, 
      new MenuItemCompat.OnActionExpandListener() { 
       @Override 
       public boolean onMenuItemActionExpand(MenuItem item) { 
        return true; 
       } 
       @Override 
       public boolean onMenuItemActionCollapse(MenuItem item) { 
        // Do something when collapsed 
        adapter.setFilter(mDataModel); 
        return true; 
       } 
      }); 
} 

@Override 
public boolean onQueryTextChange(String newText) { 
    final List<DataModel> filteredModeList = filter(mDataModel, newText); 
    adapter.setFilter(filteredModeList); 
    return true; 
} 

@Override 
public boolean onQueryTextSubmit(String query) { 
    return false; 
} 

private List<DataModel>filter(List<DataModel> models, String query){ 
    query = query.toLowerCase(); 

    final List<DataModel> filteredModeList = new ArrayList<>(); 
    for (DataModel model : models){ 
     final String text = model.getName().toLowerCase(); 
     if (text.contains(query)){ 
      filteredModeList.add(model); 
     } 
    } 
    return filteredModeList; 
    } 
} 

而且我Adapter-RVAdapter.java:

public class RVAdapter extends RecyclerView.Adapter<ItemViewHolder> { 

private List<DataModel> mDataModel; 

public RVAdapter(List<DataModel> mDataModel){ 
    this.mDataModel = mDataModel; 
} 

@Override 
public void onBindViewHolder(ItemViewHolder itemViewHolder, int position) { 
    final DataModel model = mDataModel.get(position); 
    itemViewHolder.bind(model); 
} 

@Override 
public ItemViewHolder onCreateViewHolder(ViewGroup viewGroup, int position){ 
    View view = LayoutInflater.from(viewGroup.getContext()).inflate(R.layout.list_row, viewGroup, false); 
    return new ItemViewHolder(view); 
} 

@Override 
public int getItemCount() { 
    return mDataModel.size(); 
} 

public void setFilter(List<DataModel> dataModels){ 
    mDataModel = new ArrayList<>(); 
    mDataModel.addAll(dataModels); 
    notifyDataSetChanged(); 
    } 
} 

這裏的ItemViewHolder.java:

public class ItemViewHolder extends RecyclerView.ViewHolder { 

public TextView name_TextView; 
public TextView subName_TextView; 

public ItemViewHolder(View itemView){ 
    super(itemView); 

    name_TextView = (TextView)itemView.findViewById(R.id.country_name); 
    subName_TextView = (TextView)itemView.findViewById(R.id.country_iso); 
} 

public void bind(DataModel dataModel){ 
    name_TextView.setText(dataModel.getName()); 
    subName_TextView.setText(dataModel.getSubName()); 
    } 
} 

最後,DataModel.java:

public class DataModel { 

String name; 
String subName; 

DataModel(String name, String subName){ 
    this.name = name; 
    this.subName = subName; 
} 

public String getName(){ 
    return name; 
} 

public String getSubName(){ 
    return subName; 
    } 
} 

任何幫助,建議或在正確的方向點將是真棒!

+0

您是否曾經爲此找到答案? ....好名字先生建築師;) – dazza5000

+0

還不幸 - 我打算再採取一些裂縫。如果我有任何進展,將會更新。 – ImArtVandalay

回答

0

好了,仔細看後here後,(這個答案很重要吧SED上,沒有做不到),我結束了與下面的以下內容:

:我最初測試了這一點上一個項目,有一個TabLayout,因此一些標籤有關的變量和類名。此外,我的所有佈局都與上面鏈接的帖子相同,但是使用TabLayout,CoordinatorLayout/AppBarLayout等並不困難。

這是MainFragment。java的

public class MainFragment extends Fragment implements SearchView.OnQueryTextListener { 

public static MainFragment newInstance() { 
    return new MainFragment(); 
} 

RecyclerView mRecyclerView; 
private List<MemberData> tabListItem; 
private RecyclerViewTabsAdapter mAdapter; 


@Nullable 
@Override 
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) { 

    final View view = inflater.inflate(R.layout.recyclerview, container, false); 
    mRecyclerView = (RecyclerView) view.findViewById(R.id.recyclerview); 

    return view; 
} 

@Override 
public void onViewCreated(View view, @Nullable Bundle savedInstanceState) { 
    super.onViewCreated(view, savedInstanceState); 
    setHasOptionsMenu(true); 

    mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity())); 
    mRecyclerView.setHasFixedSize(true); 

    tabListItem = new ArrayList<>(); 

    tabListItem = getTabRowList(); 

    mAdapter = new RecyclerViewTabsAdapter(getActivity(), tabListItem); 
    mRecyclerView.setAdapter(mAdapter); 
} 

@Override 
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { 
    inflater.inflate(R.menu.menu_main, menu); 
    final MenuItem item = menu.findItem(R.id.action_search); 
    final SearchView searchView = (SearchView) MenuItemCompat.getActionView(item); 
    searchView.setOnQueryTextListener(this); 
} 

@Override 
public boolean onQueryTextSubmit(String query) { 
    return false; 
} 

@Override 
public boolean onQueryTextChange(String newText) { 
    final List<MemberData> filteredModelList = filter(tabListItem, newText); 
    mAdapter.animateTo(filteredModelList); 
    mRecyclerView.scrollToPosition(0); 

    return true; 
} 

private List<MemberData> filter(List<MemberData> datas, String newText) { 
    newText = newText.toLowerCase(); 

    final List<MemberData> filteredModelList = new ArrayList<>(); 
    for (MemberData data : datas) { 
     final String text = data.getName().toLowerCase(); 
     if (text.contains(newText)) { 
      filteredModelList.add(data); 
     } 
    } 
    return filteredModelList; 
} 

private List<MemberData> getTabRowList() { 
    List<MemberData> currentItem = new ArrayList<>(); 
    currentItem.add(new MemberData("Albert", "Albert Sub", R.drawable.your_drawable)); 
    currentItem.add(new MemberData("Abby", "Abby Text", R.drawable.your_drawable)); 
    currentItem.add(new MemberData("Brian", "Brian Text", R.drawable.your_drawable)); 
    currentItem.add(new MemberData("Chris", "Chris Text", R.drawable.your_drawable)); 
    currentItem.add(new MemberData("Dante", "Dante Text", R.drawable.your_drawable)); 

//Add more of your dummy data here 


     return currentItem; 
    } 
} 

而且適配器

public class RecyclerViewTabsAdapter extends RecyclerView.Adapter<RecyclerViewTabsViewHolder> { 

private final LayoutInflater mInflater; 
private final List<MemberData>mItemList; 

public RecyclerViewTabsAdapter(Context context, List<MemberData> itemList) { 
    mInflater = LayoutInflater.from(context); 
    mItemList = new ArrayList<>(itemList); 

} 

@Override 
public RecyclerViewTabsViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { 
    final View view = mInflater.inflate(R.layout.cardview_detail, parent, false); 
    return new RecyclerViewTabsViewHolder(view); 
} 

@Override 
public void onBindViewHolder(final RecyclerViewTabsViewHolder holder, final int position) { 
    final MemberData data = mItemList.get(position); 
    holder.bind(data); 
    //TODO: Set onClick here 

} 

@Override 
public int getItemCount() { 
    return this.mItemList.size(); 

} 

public void animateTo(List<MemberData> memberDatas) { 
    applyAndAnimateRemovals(memberDatas); 
    applyAndAnimateAdditions(memberDatas); 
    applyAndAnimateMovedItems(memberDatas); 
} 

private void applyAndAnimateRemovals(List<MemberData> newDatas) { 
    for (int i = mItemList.size() - 1; i >= 0; i--) { 
     final MemberData data = mItemList.get(i); 
     if (!newDatas.contains(data)) { 
      removeItem(i); 
     } 
    } 
} 

private void applyAndAnimateAdditions(List<MemberData> newDatas) { 
    for (int i = 0, count = newDatas.size(); i < count; i++) { 
     final MemberData data = newDatas.get(i); 
     if (!mItemList.contains(data)) { 
      addItem(i, data); 
     } 
    } 
} 

private void applyAndAnimateMovedItems(List<MemberData> newDatas) { 
    for (int toPosition = newDatas.size() - 1; toPosition >= 0; toPosition--) { 
     final MemberData data = newDatas.get(toPosition); 
     final int fromPosition = mItemList.indexOf(data); 
     if (fromPosition >= 0 && fromPosition != toPosition) { 
      moveItem(fromPosition, toPosition); 
     } 
    } 
} 

public MemberData removeItem(int position) { 
    final MemberData data = mItemList.remove(position); 
    notifyItemRemoved(position); 
    return data; 
} 

public void addItem(int position, MemberData data) { 
    mItemList.add(position, data); 
    notifyItemInserted(position); 
} 

public void moveItem(int fromPosition, int toPosition) { 
    final MemberData data = mItemList.remove(fromPosition); 
    mItemList.add(toPosition, data); 
    notifyItemMoved(fromPosition, toPosition); 
    } 
} 

而且ViewHolder

public class RecyclerViewTabsViewHolder extends RecyclerView.ViewHolder { 

CardView cv; 
TextView name; 
TextView subText; 
ImageView memberPhoto; 

public RecyclerViewTabsViewHolder(View itemView){ 
    super(itemView); 
    cv = (CardView)itemView.findViewById(R.id.cv); 
    name = (TextView)itemView.findViewById(R.id.person_name); 
    subText = (TextView)itemView.findViewById(R.id.person_subtext); 
    memberPhoto = (ImageView)itemView.findViewById(R.id.person_photo); 
} 

public void bind(MemberData data){ 
    name.setText(data.getName()); 
    subText.setText(data.getSubText()); 
    memberPhoto.setImageResource(data.getPhotoId()); 
    } 
} 

最後,MemberData.java

public class MemberData { 

String name; 
String subText; 
int photoId; 

public MemberData(String name, String subText, int photoId){ 
    this.name = name; 
    this.subText = subText; 
    this.photoId = photoId; 
} 

public String getName(){ 
    return name; 
} 

public String getSubText() { 
    return subText; 
} 

public int getPhotoId() { 
    return photoId; 
    } 
} 

剩下的唯一問題(我將其保存爲另一篇文章)是onClick方法,並在列表過濾後獲取正確的位置。

希望這會有所幫助!

0

這是靈感來自於下面的帖子:

How to filter a RecyclerView with a SearchView

我需要一點更復雜的解決方案,因爲recyclerview在片段託管,因此我用了一個EventBus通過從該活動的搜索查詢正在主持searchview的片段。

從已經進入搜索查看

@Override 
public boolean onQueryTextChange(String query) { 
    EventBus.getDefault().post(new SearchEvent(query)); 
    return true; 
} 

在承載了recyclerview片段中的活動:

public void onEvent(SearchEvent e) { 
    final List<? extends GenericCompany> filteredModelList = filter(mCompanies, e.getSearchString()); 
    mListAdapter.replaceData(filteredModelList); 
    mRecyclerView.scrollToPosition(0); 
} 


private List<? extends GenericCompany> filter(List<SCSponsors> models, String query) { 
    query = query.toLowerCase(); 

    final List<SCSponsors> filteredModelList = new ArrayList<>(); 
    for (SCSponsors model : models) { 
     final String text = model.getDisplayName().toLowerCase(); 
     if (text.contains(query)) { 
      filteredModelList.add(model); 
     } 
    } 
    return filteredModelList; 
} 

適配器內部:

public void replaceData(List<? extends GenericCompany> companies) { 
     setList(companies); 
     notifyDataSetChanged(); 
    }