如何在工具栏中添加带有编辑文本的搜索栏
How to add Search bar with edit text in toolbar
我想在工具栏中添加带有编辑文本的搜索栏,如下图所示
我的toolbar.xml:-
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:local="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:minHeight="?attr/actionBarSize"
android:background="?attr/colorPrimary"
local:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
local:popupTheme="@style/ThemeOverlay.AppCompat.Light" >
<EditText
android:id="@+id/searchEditText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
/>
</android.support.v7.widget.Toolbar>
在工具栏中添加编辑文本后,我的工具栏显示如下:-
只需添加编辑文本作为工具栏的一部分,如下所示:
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/primaryColor"
android:elevation="4dp">
<EditText
android:id="@+id/searchEditText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
/>
</android.support.v7.widget.Toolbar>
我相信您正在寻找的视图是 SearchView
。您可以在 menu.xml
上定义要将其添加到 ActionBar/ToolBar。像这样:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/search"
android:icon="@drawable/search_icon"
android:title="@string/search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always" />
</menu>
返回您的 Activity 或 Fragment,您可以操纵搜索视图行为和外观:
@Override
public void onPrepareOptionsMenu(Menu menu) {
super.onPrepareOptionsMenu(menu);
MenuItem searchViewMenuItem = menu.findItem(R.id.search);
searchView = (SearchView) searchViewMenuItem.getActionView();
ImageView v = (ImageView) searchView.findViewById(android.support.v7.appcompat.R.id.search_button);
v.setImageResource(R.drawable.search_icon); //Changing the image
if (!searchFor.isEmpty()) {
searchView.setIconified(false);
searchView.setQuery(searchFor, false);
}
searchView.setQueryHint(getResources().getString(R.string.search_hint));
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
//Do your search
}
@Override
public boolean onQueryTextChange(String newText) {
if(newText.isEmpty()) clearSearch();
return false;
}
});
}
这是一种更简单的方法。最建议的方法是实际使用 activity 来响应您的搜索意图。有关这方面的更多信息,请访问:http://developer.android.com/intl/pt-br/guide/topics/search/search-dialog.html
据我了解,希望这段代码能帮到你...
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:elevation="10dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/gray_500"
android:orientation="vertical"
android:gravity="center|right">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:background="@color/white"
android:orientation="horizontal"
android:gravity="center|right">
<TextView
android:layout_width="0dp"
android:layout_height="60dp"
android:layout_weight="8"
android:layout_margin="5dp"
android:text="snap deal"
android:gravity="center" >
</TextView>
<TextView
android:layout_width="0dp"
android:layout_height="60dp"
android:layout_weight="2"
android:layout_margin="5dp"
android:ems="10"
android:text="Img"
android:gravity="center" >
</TextView>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:background="@color/white"
android:gravity="center|right">
<EditText
android:id="@+id/editMobileNo"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_margin="5dp"
android:background="@drawable/login_edittext"
android:ems="10"
android:hint="Find your dil ki deal"
android:drawableLeft="@drawable/search"
android:gravity="center" >
</EditText>
</LinearLayout>
</LinearLayout>
</android.support.v7.widget.Toolbar>
这是 EditText login_edittext.xml
的自定义形状
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape>
<gradient
android:angle="270"
android:endColor="@color/white"
android:startColor="@color/white" />
<stroke
android:width="1dp"
android:color="@color/gray_500" />
<corners
android:radius="1dp" />
<padding
android:bottom="10dp"
android:left="10dp"
android:right="10dp"
android:top="10dp" />
</shape>
</item>
</selector>
这只是草图...您需要更改颜色、尺寸、图像等.....
您可以直接将搜索视图放在工具栏内的 activity.xml 中并初始化 it.I 我猜您会得到想要的布局。
为了向后兼容,我喜欢上面的 TextEdit 解决方案。
为了实现原始示例,还有两件事需要考虑:
- 在 Activity xml TextEdit 定义中添加:
android:drawableStart="@android:drawable/ic_menu_search"
// To add the magnifying glass.
android:hint="@string/Search_Txt"
// To add the hint message.
在字符串 xml 文件中添加:
string name="Search_Txt">找到你的 dil ki 交易
// Customize your message here.
注意:SearchView 替代方案需要 API21.
尽情享受吧。
只需添加其中一项即可隐藏编辑文本的下划线。
android:background="#fff"
或
android:background="@null"
我想在工具栏中添加带有编辑文本的搜索栏,如下图所示
我的toolbar.xml:-
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:local="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:minHeight="?attr/actionBarSize"
android:background="?attr/colorPrimary"
local:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
local:popupTheme="@style/ThemeOverlay.AppCompat.Light" >
<EditText
android:id="@+id/searchEditText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
/>
</android.support.v7.widget.Toolbar>
在工具栏中添加编辑文本后,我的工具栏显示如下:-
只需添加编辑文本作为工具栏的一部分,如下所示:
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/primaryColor"
android:elevation="4dp">
<EditText
android:id="@+id/searchEditText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
/>
</android.support.v7.widget.Toolbar>
我相信您正在寻找的视图是 SearchView
。您可以在 menu.xml
上定义要将其添加到 ActionBar/ToolBar。像这样:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/search"
android:icon="@drawable/search_icon"
android:title="@string/search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always" />
</menu>
返回您的 Activity 或 Fragment,您可以操纵搜索视图行为和外观:
@Override
public void onPrepareOptionsMenu(Menu menu) {
super.onPrepareOptionsMenu(menu);
MenuItem searchViewMenuItem = menu.findItem(R.id.search);
searchView = (SearchView) searchViewMenuItem.getActionView();
ImageView v = (ImageView) searchView.findViewById(android.support.v7.appcompat.R.id.search_button);
v.setImageResource(R.drawable.search_icon); //Changing the image
if (!searchFor.isEmpty()) {
searchView.setIconified(false);
searchView.setQuery(searchFor, false);
}
searchView.setQueryHint(getResources().getString(R.string.search_hint));
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
//Do your search
}
@Override
public boolean onQueryTextChange(String newText) {
if(newText.isEmpty()) clearSearch();
return false;
}
});
}
这是一种更简单的方法。最建议的方法是实际使用 activity 来响应您的搜索意图。有关这方面的更多信息,请访问:http://developer.android.com/intl/pt-br/guide/topics/search/search-dialog.html
据我了解,希望这段代码能帮到你...
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:elevation="10dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/gray_500"
android:orientation="vertical"
android:gravity="center|right">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:background="@color/white"
android:orientation="horizontal"
android:gravity="center|right">
<TextView
android:layout_width="0dp"
android:layout_height="60dp"
android:layout_weight="8"
android:layout_margin="5dp"
android:text="snap deal"
android:gravity="center" >
</TextView>
<TextView
android:layout_width="0dp"
android:layout_height="60dp"
android:layout_weight="2"
android:layout_margin="5dp"
android:ems="10"
android:text="Img"
android:gravity="center" >
</TextView>
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1"
android:background="@color/white"
android:gravity="center|right">
<EditText
android:id="@+id/editMobileNo"
android:layout_width="match_parent"
android:layout_height="40dp"
android:layout_margin="5dp"
android:background="@drawable/login_edittext"
android:ems="10"
android:hint="Find your dil ki deal"
android:drawableLeft="@drawable/search"
android:gravity="center" >
</EditText>
</LinearLayout>
</LinearLayout>
</android.support.v7.widget.Toolbar>
这是 EditText login_edittext.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape>
<gradient
android:angle="270"
android:endColor="@color/white"
android:startColor="@color/white" />
<stroke
android:width="1dp"
android:color="@color/gray_500" />
<corners
android:radius="1dp" />
<padding
android:bottom="10dp"
android:left="10dp"
android:right="10dp"
android:top="10dp" />
</shape>
</item>
</selector>
这只是草图...您需要更改颜色、尺寸、图像等.....
您可以直接将搜索视图放在工具栏内的 activity.xml 中并初始化 it.I 我猜您会得到想要的布局。
为了向后兼容,我喜欢上面的 TextEdit 解决方案。
为了实现原始示例,还有两件事需要考虑:
- 在 Activity xml TextEdit 定义中添加:
android:drawableStart="@android:drawable/ic_menu_search"
// To add the magnifying glass.
android:hint="@string/Search_Txt"
// To add the hint message.
在字符串 xml 文件中添加:
string name="Search_Txt">找到你的 dil ki 交易
// Customize your message here.
注意:SearchView 替代方案需要 API21.
尽情享受吧。
只需添加其中一项即可隐藏编辑文本的下划线。
android:background="#fff"
或
android:background="@null"