0

我想在Tab視圖中實現搜索過濾器用sqlite數據庫中的數據進行分片,經過更多的三天後雖然thisthis沒有成功最後我碰到了this這似乎是乾淨的想法,因爲對Android開發很新鮮。 我試圖實現它,但似乎並沒有工作,這意味着搜索菜單項不充氣,我也沒有結果,我不知道我在哪裏得到錯誤,沒有任何錯誤,對什麼是錯誤的任何想法以及如何使其工作。android標籤查看片段Recycler視圖搜索過濾器

這裏是片段代碼

public class TabFragment3 extends Fragment implements SearchView.OnQueryTextListener { 
private RecyclerView recyclerView; 
private LinearLayoutManager layoutManager; 
private UsersAdapter adapter; 
ArrayList<HashMap<String, String>> arrayList; 
DBController controller = new DBController(getContext()); 
@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { 
    View view =inflater.inflate(R.layout.tab_fragment_3, container, false); 
    recyclerView = (RecyclerView) view.findViewById(R.id.usersList); 
    recyclerView.setHasFixedSize(true); 
    layoutManager = new LinearLayoutManager(getContext()); 
    recyclerView.setLayoutManager(layoutManager); 
    controller = new DBController(getContext()); 
    arrayList = controller.getAllUsers(); 
    adapter = new UsersAdapter(arrayList,getContext()); 
    recyclerView.setAdapter(adapter); 
    adapter.notifyDataSetChanged(); 
    return view; 
     } 

@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 onMenuItemActionCollapse(MenuItem item) { 
      arrayList = controller.getAllUsers(); 
      // Do something when collapsed 
      adapter.setFilter(arrayList); 
      return true; // Return true to collapse action view 
     } 

     @Override 
     public boolean onMenuItemActionExpand(MenuItem item) { 
      // Do something when expanded 
      return true; // Return true to expand action view 
     } 
    }); 
} 

@Override 
public boolean onQueryTextChange(String query) { 
    return false; 
} 
@Override 
public boolean onQueryTextSubmit(String newText) { 
// Here is where we are going to implement the filter logic 
    newText = newText.toLowerCase(); 
    ArrayList<HashMap<String, String>> userlist = controller.getAllUsers(); 
    ArrayList<HashMap<String, String>> newList= new ArrayList<>(); 
    for(HashMap<String, String> entry : userlist){ 
     String name2= entry.get("number").toLowerCase(); 
     if(name2.contains(newText)){ 
      newList.add(entry); 
     }} 
    adapter.setFilter(newList); 
    return true; 
} 

}

/// adapter class 

public class UsersAdapter extends RecyclerView.Adapter<UsersAdapter.UserViewHolder> { 
ArrayList<HashMap<String, String>> mDataSet= new ArrayList<HashMap<String, String>>(); 
Context ctx; 
public UsersAdapter(ArrayList<HashMap<String, String>> mDataSet,Context ctx) { 
    this.mDataSet = mDataSet; 
    this.ctx=ctx; 
} 
@Override 
public UserViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { 
    View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.user_row, parent, false); 
    UserViewHolder userViewHolder = new UserViewHolder(v,mDataSet,ctx); 
    return userViewHolder; 
} 
@Override 
public void onBindViewHolder(UserViewHolder holder, int position) { 
    holder.name_entry.setText(mDataSet.get(position).get("userId")); 
    holder.email_entry.setText(mDataSet.get(position).get("userName")); 
    holder.icon_entry.setText(""+mDataSet.get(position).get("number")); 
} 
@Override 
public int getItemCount() { 
    return mDataSet.size(); 
} 

public static class UserViewHolder extends RecyclerView.ViewHolder { 
    CardView cardView; 
    TextView name_entry, email_entry, icon_entry; 
    Context ctx; 
    ArrayList<HashMap<String, String>> mDataSet= new ArrayList<HashMap<String, String>>(); 
    public UserViewHolder(View itemView, ArrayList<HashMap<String, String>> mDataSet,Context ctx) { 
     super(itemView); 
     this.mDataSet=mDataSet; 
     this.ctx= ctx; 
     cardView = (CardView) itemView.findViewById(R.id.user_layout); 
     name_entry = (TextView) itemView.findViewById(R.id.name_entry); 
     email_entry = (TextView) itemView.findViewById(R.id.email_entry); 
     icon_entry = (TextView) itemView.findViewById(R.id.icon_entry); 
    } 
} 

@Override 
public void onAttachedToRecyclerView(RecyclerView recyclerView) { 
    super.onAttachedToRecyclerView(recyclerView); 
} 
public void setFilter(ArrayList<HashMap<String, String>> newList){ 
    mDataSet= new ArrayList<HashMap<String, String>>(); 
    mDataSet.addAll(newList); 
    notifyDataSetChanged(); 
} 

}

///主

public class MainActivity extends AppCompatActivity implements TabLayout.OnTabSelectedListener,SearchView.OnQueryTextListener { 
private ViewPager viewPager; 
PagerAdapter adapter; 
@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
    setSupportActionBar(toolbar); 
    TabLayout tabLayout = (TabLayout) findViewById(R.id.tab_layout); 
    tabLayout.addTab(tabLayout.newTab().setText("Tab 1")); 
    tabLayout.addTab(tabLayout.newTab().setText("Tab 2")); 
    tabLayout.addTab(tabLayout.newTab().setText("Tab 3")); 
    tabLayout.setTabGravity(TabLayout.GRAVITY_FILL); 

    final ViewPager viewPager = (ViewPager) findViewById(R.id.pager); 
    adapter = new PagerAdapter 
      (getSupportFragmentManager(), tabLayout.getTabCount()); 
    viewPager.setAdapter(adapter); 
    viewPager.addOnPageChangeListener(new TabLayout.TabLayoutOnPageChangeListener(tabLayout)); 
    tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() { 
     @Override 
     public void onTabSelected(TabLayout.Tab tab) { 
      viewPager.setCurrentItem(tab.getPosition()); 
     } 

     @Override 
     public void onTabUnselected(TabLayout.Tab tab) { 

     } 

     @Override 
     public void onTabReselected(TabLayout.Tab tab) { 

     } 
    }); 
} 

@Override 
public void onTabSelected(TabLayout.Tab tab) { 
    viewPager.setCurrentItem(tab.getPosition()); 
} 

@Override 
public void onTabUnselected(TabLayout.Tab tab) { 

} 
@Override 
public void onTabReselected(TabLayout.Tab tab) { 
} 
@Override 
public boolean onCreateOptionsMenu(Menu menu) { 
    getMenuInflater().inflate(R.menu.menu_main, menu); 
    return true; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    int id = item.getItemId(); 
    return super.onOptionsItemSelected(item); 
} 

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

    return false; 
     } 

}

+0

你面臨什麼問題?搜索菜單項是不是在膨脹?或者你沒有得到結果?或者它是什麼? – iMDroid

+0

它不會膨脹,因此即使沒有找到結果@ Sherl0cked –

回答

2
  1. 在您的TabFragment3的onCreateView()方法中添加setHasOptionsMenu(true)方法。它告訴主機活動你的片段有它想要添加的菜單選項。

  2. 另外補充super.onCreateOptionsMenu(menu,inflater) ..

    @Override public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) { inflater.inflate(R.menu.menu_main, menu); super.onCreateOptionsMenu(menu,inflater); }

  3. 裏面在MainActivity的onOptionsItemSelected(MenuItem item)回報虛假,作爲菜單項行動將在TabFragment3的onOptionsItemSelected(MenuItem item)被hanlded。

+0

我試過這個概念,但仍然無法工作@ Sherl0cked –

+0

沒有解決任何問題?仍然無法看到工具欄中的搜索圖標? – iMDroid

+0

搜索我是那裏,但它不充氣@ Sherl0cked –