代码之家  ›  专栏  ›  技术社区  ›  neteot

在android工具栏中展开搜索视图时,将图标推离

  •  6
  • neteot  · 技术社区  · 8 年前

    我面临着这种特殊的行为,我不知道如何解决它。。

    在我的活动中,我有一个工具栏:

    enter image description here

    当你点击搜索图标时,它会展开并将另一个图标推到视图之外。

    enter image description here

    我想知道如何保持图标在右侧并减少搜索视图空间。

    这是我的菜单布局:

    <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>
    

    有没有人知道如何实现我想要的。。

    非常感谢。

    3 回复  |  直到 8 年前
        1
  •  11
  •   Bob    8 年前

    使用 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"/>
    
        2
  •  0
  •   jaibatrik    8 年前

    更改 showAsAction 把某事归因于某人 ifRoom 并尝试-

    <item
      android:id="@+id/alimentos_basket"
      android:orderInCategory="1"
      android:title="@string/alimentos_anadidos"
      app:showAsAction="ifRoom" />
    
        3
  •  0
  •   saff1x    2 年前

    对我有用的是从菜单资源文件中删除“action_search”,而使用MaterialToolbar将SearchView包装在活动xml布局中。

    <com.google.android.material.appbar.MaterialToolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:layout_constraintTop_toTopOf="parent"
            app:menu="@menu/your_menu">
            
            <androidx.appcompat.widget.SearchView
                android:id="@+id/searchView"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="end"
                app:iconifiedByDefault="true"
                app:queryBackground="@color/transparent"
                app:queryHint="@string/search..." />
    
    
        </com.google.android.material.appbar.MaterialToolbar>
    

    在活动中,您可以使用setSupportActionBar()并传递工具栏