单击 SearchView 上的更改工具栏 color/style
Change Toolbar color/style on SearchView click
我有一个简单的问题。
如何在单击“搜索”图标时将工具栏的 color/or 主题更改为白色?
我希望在单击搜索图标时工具栏为白色(后退箭头颜色为 black/grey)。我在 MenuItem
中添加了 SearcView (android.support.v7.widget.SearchView)
这个
到
然后在单击“后退”按钮时返回原始工具栏颜色。
在Activity
/Fragment
代码中:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.activity_menu, menu);
MenuItem searchMenuItem = menu.findItem(R.id.search);
if (searchMenuItem == null) {
return true;
}
searchView = (SearchView) searchMenuItem.getActionView();
MenuItemCompat.setOnActionExpandListener(searchMenuItem, new MenuItemCompat.OnActionExpandListener() {
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
// Set styles for expanded state here
if (getSupportActionBar() != null) {
getSupportActionBar().setBackgroundDrawable(new ColorDrawable(Color.RED));
}
return true;
}
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
// Set styles for collapsed state here
if (getSupportActionBar() != null) {
getSupportActionBar().setBackgroundDrawable(new ColorDrawable(Color.BLUE));
}
return true;
}
});
return true;
}
而实际 menu
的 xml 是:
<?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:title="@string/search_title"
android:icon="@drawable/ic_menu_search"
app:showAsAction="always|collapseActionView"
app:actionViewClass="android.support.v7.widget.SearchView" />
</menu>
要更改 back/X-buttons 展开视图的颜色,请将其添加到您的样式中:
<item name="colorControlNormal">@color/my_great_color</item>
要使颜色的变化更平滑 - 您可以将其设置为动画:Animate change of view background color on Android
希望对你有所帮助
我有一个简单的问题。
如何在单击“搜索”图标时将工具栏的 color/or 主题更改为白色?
我希望在单击搜索图标时工具栏为白色(后退箭头颜色为 black/grey)。我在 MenuItem
中添加了 SearcView (android.support.v7.widget.SearchView)这个
到
然后在单击“后退”按钮时返回原始工具栏颜色。
在Activity
/Fragment
代码中:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.activity_menu, menu);
MenuItem searchMenuItem = menu.findItem(R.id.search);
if (searchMenuItem == null) {
return true;
}
searchView = (SearchView) searchMenuItem.getActionView();
MenuItemCompat.setOnActionExpandListener(searchMenuItem, new MenuItemCompat.OnActionExpandListener() {
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
// Set styles for expanded state here
if (getSupportActionBar() != null) {
getSupportActionBar().setBackgroundDrawable(new ColorDrawable(Color.RED));
}
return true;
}
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
// Set styles for collapsed state here
if (getSupportActionBar() != null) {
getSupportActionBar().setBackgroundDrawable(new ColorDrawable(Color.BLUE));
}
return true;
}
});
return true;
}
而实际 menu
的 xml 是:
<?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:title="@string/search_title"
android:icon="@drawable/ic_menu_search"
app:showAsAction="always|collapseActionView"
app:actionViewClass="android.support.v7.widget.SearchView" />
</menu>
要更改 back/X-buttons 展开视图的颜色,请将其添加到您的样式中:
<item name="colorControlNormal">@color/my_great_color</item>
要使颜色的变化更平滑 - 您可以将其设置为动画:Animate change of view background color on Android
希望对你有所帮助