SearchView的学习笔记
JasonDev324

OK

SearchView的理解

默认操作
点击搜索按钮,展开搜索框,点击软键盘搜索按钮即可。

使用步骤
1.在xml中使用android.support.v7.widget.SearchView标签。
2.在java中使用setOnQueryTextListener方法即可。重写onQueryTextSubmit、onQueryTextChange两个方法。

XML常用属性

1
2
3
4
5
6
7
8
9
10
<!-- 默认状态下,SearchView是需要点击搜索按钮才展开输入框。该属性设置为false,则不需点击直接展开输入框 -->
android:iconifiedByDefault
<!-- 设置IME options,即输入法的回车键的功能,可以是搜索、下一个、发送、完成等等。这里actionSearch表示搜索 -->
android:imeOptions
<!-- 输入框默认文本 -->
app:queryHint
<!-- 去除下划线以及设置背景 -->
app:queryBackground="@null"
<!-- 去除SearchView的左边图标-->
app:searchIcon="";

JAVA中常用的方法

1
2
3
4
5
6
7
8
9
10
11
12
13
//设置搜索框默认是否自动缩小为图标。
setIconifiedByDefault(boolean iconified)
// 为搜索框设置监听器
setOnQueryTextListener(SearchView,OnQueryTextListener listener)
// 设置是否显示搜索按钮
setSubmitButtonEnabled(boolean enabled)
// 设置搜索框内的默认显示的提示文本
setQueryHint(CharSequence hint)
onQueryTextSubmit是点击搜索后的Listener 返回true,键盘不消失,返回false,键盘消失。
onQueryTextChange是搜索框内容变化的Listener

// 手动展开SearchView输入框
onActionViewExpanded

searchView空查询

searchView不能进行空查询
解决方法
可以通过onQueryTextChange 来实现text为空时,自动查询

1
2
3
4
5
6
7
8
9
@Override
public boolean onQueryTextChange(String newText) {
if (TextUtils.isEmpty(newText)) {
keyWord = newText;
pageNo = 1;
refreshLayout.refresh();
}
return false;
}

示例 - 修改SearchView样式

技巧
查看SearchView的布局文件,点击进去是R文件,无法查看布局内容。
解决方法
在AS的全局搜索框中搜索该布局即可查看该布局内容。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
//需求 —— 修改Searchview字体大小颜色,同时需要重新布局使Text居中

//根据id-search_src_text获取TextView
SearchView.SearchAutoComplete searchText = (SearchView.SearchAutoComplete) searchView.findViewById(R.id.search_src_text);
//修改字体大小
searchText.setTextSize(TypedValue.COMPLEX_UNIT_DIP, 14);
//重新布局,使其居中
LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
lp.gravity = Gravity.CENTER_VERTICAL;
searchText.setLayoutParams(lp);
//修改字体颜色
searchText.setTextColor(ContextCompat.getColor(this, R.color.common_text_gray));
searchText.setHintTextColor(ContextCompat.getColor(this, R.color.common_text_gray));


// 由于通过xml属性app:searchIcon来修改图标的样式会导致drawable过大(显示不正常)。
// 经研究是因为SearchView里ImageVIew设置了padding导致的结果。所以只能通过动态布局来修改。

//需求 —— 修改SearchView左边图标

//根据id-search_mag_icon获取ImageView
ImageView searchButton = (ImageView) searchView.findViewById(R.id.search_mag_icon);
//重新设置ImageView的宽高,使其为自适应图片宽高
LinearLayout.LayoutParams lpimg = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
lpimg.gravity = Gravity.CENTER_VERTICAL;
searchButton.setLayoutParams(lpimg);
searchButton.setImageResource(R.drawable.goods_search_icon);

//该项用于测试ImageView的宽高大小
// searchButton.setBackgroundColor(Color.BLUE);
1
2
3
4
5
6
7
8
9
10
11
12
<android.support.v7.widget.SearchView
android:id="@+id/searchView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@null"
app:closeIcon="@null"
app:defaultQueryHint="请输入搜索内容"
app:iconifiedByDefault="false"
app:queryBackground="@null"
app:queryHint="请输入搜索内容" />

<!-- app:searchIcon="@null" 这句不应该使用,否则默认不显示自定义icon,要点击才显示-->
Powered by Hexo & Theme Keep
Total words 22k Unique Visitor Page View