首页 > 解决方案 > 处理对 SearchView 图标的点击

问题描述

首先,我将向您解释我想做什么。然后,我将向您展示我已经完成的工作。最后,我会就我将要实施的内容寻求您的帮助。

我的目标

我的目标是拥有一个Toolbar像 Playstore 一样的商店:在此处输入图像描述

当您单击汉堡菜单时,它会显示菜单。当您单击输入时,它会显示更改图标并显示键盘:

在此处输入图像描述

我现在拥有的

在此处输入图像描述

我遵循了文档(https://developer.android.com/training/appbar/ + https://developer.android.com/guide/topics/search/search-dialog + https://developer.android.com/培训/搜索/设置)。因此,我有:

  1. res/menu/action_bar_menu.xml包含我的SearchView小部件
<?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/searchView"
        android:title="@string/search_title"
        app:actionViewClass="android.support.v7.widget.SearchView"
        app:showAsAction="always" />

</menu>
  1. AToolbar在我的片段布局中:
    <android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    android:background="@color/colorRoyalRed"
    android:theme="@style/ToolbarStyle"
    app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
  1. 风格ToolbarStyle(见上):
<style name="ToolbarStyle">
    <item name="android:background">@color/colorRoyalRed</item>
    <item name="android:textColorPrimary">@color/colorRichYellow</item>
    <item name="actionButtonStyle">@style/ToolbarActionButton</item>
</style>
<style name="ToolbarActionButton">
    <item name="android:padding">0dp</item>
    <item name="android:paddingStart">0dp</item>
    <item name="android:paddingEnd">0dp</item>
</style>
  1. 在片段类中,我使用了工具栏:
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_home, container, false);
    Toolbar toolbar = view.findViewById(R.id.toolbar);
    toolbar.setTitle("");
    AppCompatActivity app_compat_activity = (AppCompatActivity) getActivity();
    Objects.requireNonNull(app_compat_activity).setSupportActionBar(toolbar);
    app_compat_activity.getWindow().setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_HIDDEN);

    return view;
}
  1. 在片段类中,我使用了SearchView
    @Override
    public void onCreateOptionsMenu(Menu menu, MenuInflater menu_inflater) {
        menu_inflater.inflate(R.menu.action_bar_menu, menu);
        super.onCreateOptionsMenu(menu,menu_inflater);

        AppCompatActivity app_compat_activity = (AppCompatActivity) getActivity();


SearchView search_view = (SearchView) menu.findItem(R.id.searchView).getActionView();
        search_view.setIconifiedByDefault(false);
        SearchManager search_manager = (SearchManager) Objects.requireNonNull(app_compat_activity).getSystemService(Context.SEARCH_SERVICE);
        search_view.setSearchableInfo(Objects.requireNonNull(search_manager).getSearchableInfo(app_compat_activity.getComponentName()));
    }

好吧,还有其他实现(有关清单的修改等),但它们并不重要(请注意在工具栏中实现简单搜索栏所需的所有更改......超过 5 个步骤......)。

接下来我想做什么(请帮助!)

我不想使用菜单项结构以外的任何东西(因此我不想SearchView在片段的布局中实际添加)。

  1. 我怎么能改变SearchView的图标?现在它是一个放大镜。一定是汉堡菜单。我试图res/menu/action_bar_menu.xml通过向 the 指示 aandroid:icon=来进行修改,SearchView但它没有用。我也尝试<item name="searchIcon">@drawable/ic_baseline_menu_24px</item>在样式中使用,ToolbarActionButton但没有奏效。这里的目的是用汉堡菜单图标替换玻璃。

  2. 我如何处理对SearchView的汉堡菜单图标的点击(一旦它被设置)?确实,我会打电话给我的DrawerLayout::openDrawer函数来打开我的菜单。

  3. 我怎么能处理点击SearchView内容的点击?实际上,我将用左箭头替换汉堡菜单(如果单击,键盘将消失并显示汉堡菜单)。

我使用了错误的东西吗?

我只是按照谷歌的文档。但是对我来说,意识到我可能走错了路似乎很复杂?我应该停止使用菜单项结构吗?

标签: androidandroid-toolbarsearchview

解决方案


您可以尝试此 Google 项目下的 SearchEditTextLayout - https://android.googlesource.com/platform/packages/apps/Dialer/

这些库还可以帮助您实现所需的结果。

SearchViewFloatingSearchView


推荐阅读