我正面临这种特殊行为,我不知道如何修复它。
在我的活动中,我有这个工具栏:
当您点击搜索图标时,它会展开并将另一个图标推出视图。
我想知道如何将图标保留在右侧并缩小搜索视图空间。
这是我的菜单布局:
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/action_search"
android:title="@string/buscar"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always" />
<item
android:id="@+id/alimentos_basket"
android:orderInCategory="1"
android:title="@string/alimentos_anadidos"
app:showAsAction="always" />
在我的活动布局中,我没有任何内容
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="com.irixgalicia.irixhealth.app.comidaDiaria.AnadirAlimentoActivity">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay">
</android.support.v7.widget.Toolbar>
</android.support.design.widget.AppBarLayout>
<include layout="@layout/content_anadir_alimento" />
这些是我充气的活动代码
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_anadir_alimento, menu);
final MenuItem menuItem = menu.findItem(R.id.action_search);
final SearchView searchView = (SearchView) MenuItemCompat.getActionView(menuItem);
searchView.setOnQueryTextListener(this);
final MenuItem contadorItem = menu.findItem(R.id.alimentos_basket);
contadorItem.setIcon(buildCounterDrawable(contadorAlimentos, R.drawable.ic_food_variant_white_36dp));
return super.onCreateOptionsMenu(menu);
}
在我的布局中,我只有工具栏,而不是里面的图标。
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay">
</android.support.v7.widget.Toolbar>
</android.support.design.widget.AppBarLayout>
有谁知道如何实现我正在寻找的东西..
谢谢!
答案 0 :(得分:11)
使用ifRoom|collapseActionView
作为属性showAsAction
<item
android:id="@+id/action_search"
android:title="search"
app:actionViewClass="android.support.v7.widget.SearchView"
android:icon="@drawable/ic_search"
app:showAsAction="ifRoom|collapseActionView"/>
答案 1 :(得分:0)
将showAsAction
属性更改为ifRoom
并尝试 -
<item
android:id="@+id/alimentos_basket"
android:orderInCategory="1"
android:title="@string/alimentos_anadidos"
app:showAsAction="ifRoom" />