效果(不動請戳大圖)
toolbar.gif
ToolBar添加 menu
toolbar.inflateMenu(R.menu.toolbar_menu);
menu 文件
<menu>
<item
android:id="@+id/action_search_kl"
android:title="@string/action_search_knowledge"
android:orderInCategory="80"
app:actionViewClass="android.support.v7.widget.SearchView"
android:icon="@drawable/ic_search"
app:showAsAction="always" />
</menu>
根據 itemId 找到該 item
MenuItem item= toolbar.findViewById(R.id.action_search_kl);
通過 menuitem 獲取里面的 view,進行各種樣式更改
private void initSearchView(final MenuItem item){
//通過 item 獲取 actionview
final SearchView searchView = (SearchView) item.getActionView();
searchView.setQueryHint("搜索知識庫");
//改變默認的搜索圖標
((ImageView)searchView.findViewById(R.id.search_button)).setImageResource(R.drawable.ic_search);
//搜索監聽
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
//在輸入法按下搜索或者回車時,會調用次方法,在這里可以作保存歷史記錄的操作,我這里用了 sharepreference保存
SPUtils spUtils = new SPUtils("knowledgeHistory");
spUtils.put(query, query);
presenter.searchKnowledge(query);
return false;
} @Override
public boolean onQueryTextChange(String newText) {
//輸入字符則回調此方法
//當輸入字符為空時,重新設置 item
if(newText==null||newText.length()==0){
//由于實現了歷史數據的功能,在此重新設置此 item才能實時生效
initSearchView(item); }
return false;
}
});
//根據id-search_src_text獲取TextView
searchViewOfKnowledge = (SearchView.SearchAutoComplete) searchView.findViewById(R.id.search_src_text);
//改變輸入文字的顏色
searchViewOfKnowledge.setTextColor(ContextCompat.getColor(HomeTabActivity.this, R.color.colorAccent));
try {
//取出歷史數據,你可以利用其他方式
final List<String> arr = new ArrayList<>();
SPUtils spUtils = new SPUtils("knowledgeHistory");
Map<String, ?> map = spUtils.getAll();
for (String key : map.keySet()) {
arr.add(map.get(key).toString());
}
//顯示歷史數據列表
searchViewOfKnowledge.setThreshold(0);
//歷史數據列表的 adapter,必須繼承 ArrayAdater 或實現 filterable接口
HistoryAdapter adapter = new HistoryAdapter(HomeTabActivity.this, R.layout.item_history, arr,searchView);
//設置 adapter
searchViewOfKnowledge.setAdapter(adapter);
//如果重寫了 Adapter 的 getView 方法,可以不用實現 item 監聽(實現了也沒用),否則必須實現監聽,不然會報錯
searchViewOfKnowledge.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int position, long l) {
searchView.setQuery(arr.get(position), true);
}
});
} catch (NullPointerException e) {
e.printStackTrace();
}
//searchview 的關閉監聽
searchView.setOnCloseListener(new SearchView.OnCloseListener() { @Override public boolean onClose() {
return false;
}
});}
歷史列表的 adapter,帶刪除功能
item 布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal"
android:gravity="center_vertical"
android:layout_width="match_parent"
android:background="@drawable/touch_bg"
android:padding="10dp"
android:clickable="true"
android:layout_height="wrap_content">
<TextView
android:id="@+id/titleTv"
android:text="hahaha"
android:layout_centerVertical="true"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
<ImageButton
android:background="@drawable/ic_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_alignParentRight="true"
android:layout_gravity="right"
android:id="@+id/imageButton" />
</RelativeLayout>
adapter
構造方法必須帶有布局ID,傳入SearchView 是為了點擊 item 之后可以在SearchView 直接顯示點擊的文字
public HistoryAdapter(Context context, int resourceId, List<String> titles,SearchView searchView) {
super(context, resourceId, objects);
this.context=context;
this.titles=titles;
this.resourceId=resourceId;
this.searchView=searchView;
}
省略 getItem,getCount,getItemId方法,主要看 getView 中刪除按鈕的點擊方法
holder.imageButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
SPUtils spUtils = new SPUtils("knowledgeHistory");
//從數據中移除該項
spUtils.remove(titles.get(i));
//從數據中移除該項
titles.remove(i);
//進行刷新
notifyDataSetChanged(); }});
必須重寫 ArrayAdapter的getFilter()方法,如果不重寫此方法,只會一直顯示歷史列表,則無法實現輸入文字進行篩選的效果
//用于保存原始數據
private List<String> mOriginalValues;
@NonNull@Override
public Filter getFilter() {
Filter filter = new Filter() {
@SuppressWarnings("unchecked")
@Override
protected void publishResults(CharSequence constraint,FilterResults results) {
titles = (List<String>) results.values; // 得到篩選后的列表結果
notifyDataSetChanged(); // 刷新數據 }
@Override
protected FilterResults performFiltering(CharSequence constraint) {
FilterResults results = new FilterResults();
List<String> filteredArrList = new ArrayList<String>();
if (mOriginalValues == null) {
//保存一份未篩選前的完整數據
mOriginalValues = new ArrayList<String>(titles);
} if (constraint == null || constraint.length() == 0) { //如果接收到的文字為空,則不作比較,直接返回未篩選前的完整數據
results.count = mOriginalValues.size();
results.values = mOriginalValues;
} else {
//遍歷原始數據,與接收到的文字作比較,得到篩選結果
constraint = constraint.toString().toLowerCase();
for (int i = 0; i < mOriginalValues.size(); i++) {
String data = mOriginalValues.get(i); if(data.toLowerCase().startsWith(constraint.toString())) {
filteredArrList.add(data);
}
}
//返回得到的篩選列表
results.count = filteredArrList.size();
results.values = filteredArrList; } return results; } }; return filter;}