将SearchView与AppCompatActivity一起使用会导致UI故障

Yha*_*oer 6 user-interface android android-appcompat searchview

我正在尝试使用操作栏中的搜索按钮创建一个Android应用程序,当用户按下搜索按钮时,操作栏上会出现一个搜索文本框,就像Google的Messenger应用程序一样(见下文). 谷歌的Messenger与崩溃的搜索行动. Google的Messenger,扩展了搜索操作.

我试图实现它,如下所示,但我的应用程序看起来像这样: 我的应用有折叠搜索操作 我的应用扩展了搜索操作

这有一些问题.例如,文本用省略号读取"搜索...",不像没有省略号的简单"搜索",但到目前为止最关注的是,工具栏中没有后退按钮,搜索按钮被按下在左边太远,右边的溢出按钮被推到一边.此外,按下我的设备上的物理后退按钮不会折叠搜索视图,它只是存在于应用程序.

我过去尝试实现搜索栏的一些代码如下.我尝试设置SearchViewExpandListener如下所示,以便在展开搜索视图时显示后退按钮,但它不起作用.

编辑:我还在我onMenuItemActionExpandonMenuItemActionCollapsed方法上使用断点运行应用程序,我发现这些方法实际上从未调用过.

MainActivity.java

import android.content.Context;
import android.support.v4.view.MenuItemCompat;
import android.support.v4.view.ViewPager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.SearchView;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.Toast;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);
        getSupportActionBar().setDisplayShowHomeEnabled(false);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu, menu);

        MenuItem searchItem = menu.findItem(R.id.action_search);
        SearchView searchView = (SearchView) MenuItemCompat.getActionView(searchItem);
        // See above
        MenuItemCompat.setOnActionExpandListener(searchItem, new SearchViewExpandListener(this));
        MenuItemCompat.setActionView(searchItem, searchView);

        searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {

            @Override
            public boolean onQueryTextSubmit(String s) {
                Toast.makeText(MainActivity.this, "You searched " + s, Toast.LENGTH_SHORT).show();
                return false;
            }

            @Override
            public boolean onQueryTextChange(String s) {
                return false;
            }
        });
        return true;
    }

// See above
    private class SearchViewExpandListener implements MenuItemCompat.OnActionExpandListener {

        private Context context;

        public SearchViewExpandListener (Context c) {
            context = c;
        }

        @Override
        public boolean onMenuItemActionExpand(MenuItem item) {
            ((AppCompatActivity) context).getSupportActionBar().setDisplayShowHomeEnabled(true);
            return false;
        }

        @Override
        public boolean onMenuItemActionCollapse(MenuItem item) {
            ((AppCompatActivity) context).getSupportActionBar().setDisplayShowHomeEnabled(false);
            return false;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

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/action_search"
        android:title="Search"
        app:actionViewClass="android.support.v7.widget.SearchView"
        app:showAsAction="ifRoom"/>

    <item android:id="@+id/action_about"
        android:title="About"
        app:showAsAction="never"/>
</menu>
Run Code Online (Sandbox Code Playgroud)

它似乎也不仅仅是我有这个问题.有关实施SearchView的指南似乎遇到了类似的问题.

这家伙的问题就像我的一样.

那么在AppCompatActivity中实现搜索栏的正确方法是什么呢?这会导致Google的Material Design指南中的搜索栏与Google Messenger等应用程序中的搜索栏类似?我觉得我过去一直在谷歌上无休止地搜索,但我找不到任何有帮助我的东西.

Bha*_*nki 3

在serchView菜单项上使用collapseActionViewflag和alwaysinshowAsAction

app:showAsAction="always|collapseActionView"
Run Code Online (Sandbox Code Playgroud)

collapseActionView标志指示当用户未与其交互时如何显示小部件:如果小部件位于应用程序栏上,则应用程序应将小部件显示为图标。如果小部件位于溢出菜单中,则应用程序应将小部件显示为菜单项。当用户与操作视图交互时,它会扩展以填充应用程序栏。