Android SearchView 图标

Posted

技术标签:

【中文标题】Android SearchView 图标【英文标题】:Android SearchView Icon 【发布时间】:2012-12-09 23:29:33 【问题描述】:

我想禁用显示在搜索视图组件中的 Mag 图标。知道如何引用它并将其删除或用另一个可绘制对象替换它吗?

【问题讨论】:

想知道为什么有人会否决这个问题? SearchView 图标下方的白线怎么样 - 如何自定义? 你有想过这个吗? @mattblang 是的。请给我发电子邮件我会尝试提取代码并分享它 【参考方案1】:

由于问题的措辞不包含任何提及ActionBarSherlock(标签除外)并且已添加 cmets 接受的答案不适用于标准和/或支持库操作栏,我发布另一个答案。这是onCreate的Java代码:

// obtain action bar
ActionBar actionBar = getSupportActionBar();

// find SearchView (im my case it's in a custom layout because of left alignment)
View v = actionBar.getCustomView();
SearchView searchView = (SearchView)v.findViewById(R.id.search_view);
ImageView icon = (ImageView)searchView.findViewById(android.support.v7.appcompat.R.id.search_mag_icon);

// method 1: does not work persistently, because the next line
// should be probably called after every manipulation with SearchView
// icon.setVisibility(View.GONE);

// method 2: working code
icon.setAdjustViewBounds(true);
icon.setMaxWidth(0);
icon.setLayoutParams(new LinearLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));
icon.setImageDrawable(null);

根据这个post,同时使用支持库中的SearchView(在我的情况下为android-support-v7-appcompat)和setIconifiedByDefault(false),图标显示在编辑文本框(SearchAutoComplete)之外。否则 (setIconifiedByDefault(true)) 它会显示在框内。默认情况下,呈现的代码用于禁用“图标化”,并且可能需要进行一些更改才能与“图标化”搜索视图一起使用。我不知道这是否同样适用于ActionBarSherlock

希望这会有所帮助。

【讨论】:

我正在使用 appcompat SearchView,我在编辑文本框中有那个图标,我无法让它消失。您还有其他想法吗? 您可能应该检查您的库是哪个版本并查看其来源,特别是在布局文件中。例如,如果您查看this Android sources,您会看到search_mag_iconsearch_plate 之外。通过源代码,您可以推断要在布局中“找到”哪些元素。 我拥有 SupportLibrary 的最新版本,并且在资源中 search_mag_icon 无处不在。可能该图标不是 search_mag_icon 而是 SearchAutoComplete 中的某个图标?我怎样才能找到这方面的资源? 好吧,我昨天也更新了库,上面的代码对我有用。我想您的项目中可能还有其他特定的东西。您能否在单独的问题中发布一些代码和详细解释,说明问题所在? @Andrew,不,我没有。【参考方案2】:

这个图标是提示。所以你可以简单地设置新的提示文本。

int searchPlateId = searchView.getContext().getResources().getIdentifier("android:id/search_src_text", null, null);
    EditText searchPlate = (EditText) searchView.findViewById(searchPlateId);

    searchPlate.setHint("Search");

如果您希望图标作为提示文本,请使用带有 ImageSpan 的可扩展字符串

int searchPlateId = searchView.getContext().getResources().getIdentifier("android:id/search_src_text", null, null);
    EditText searchPlate = (EditText) searchView.findViewById(searchPlateId);


    searchPlate.setTextColor(getResources().getColor(R.color.search_text_color));
    SpannableString string = new SpannableString(" ");
    Drawable d = getResources().getDrawable(R.drawable.ic_search);
    d.setBounds(0, 0, d.getIntrinsicWidth(), d.getIntrinsicHeight());
    ImageSpan span = new ImageSpan(d, ImageSpan.ALIGN_BOTTOM);
    string.setSpan(span, 0, 1, Spannable.SPAN_INCLUSIVE_EXCLUSIVE);
    searchPlate.setHint(string);

【讨论】:

【参考方案3】:

在您的主题中:

<style name="Theme" parent="Your parent theme">
<item name="android:searchViewSearchIcon">@android:drawable/ic_search</item>
</style>

编辑:searchViewSearchIcon 是私有属性。因此,此答案不起作用(在本机 ActionBar 上)。

【讨论】:

将其设置为 @android:color/transparent 以将其删除,或将其更改为您想要的。 天哪。这太棒了。非常感谢。我不必再发布与操作栏样式相关的问题了:D 嗨 @Ahmad 我正在使用 但它给了我“找不到与给定名称匹配的资源:attr 'android:searchViewSearchIcon'” android:searchViewSearchIcon 是私有的。这个答案根本不起作用。 适用于我的 2.3 到 4.4 的 ABC。谢谢!【参考方案4】:

你必须在你的 MenuItem 中添加这一行 android:iconifiedByDefault="@android:color/transparent"

<item
    android:id="@+id/activity_home_action_search"
    android:icon="@drawable/ic_action_search"
    android:title="@string/activity_home_search_title"
    android:iconifiedByDefault="@android:color/transparent"
    app:actionViewClass="android.support.v7.widget.SearchView"
    app:showAsAction="always|collapseActionView" />

或者您可以通过编程方式制作searchView.setIconifiedByDefault(true);

@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) 
    super.onCreateOptionsMenu(menu, inflater);
    getMenuInflater().inflate(R.menu.home, menu);

    MenuItem searchMenuItem = menu.findItem(R.id.activity_home_action_search);

    SearchView searchView = (SearchView) searchMenuItem.getActionView();
    searchView.setIconifiedByDefault(true);

【讨论】:

【参考方案5】:

移除提示搜索按钮:

mNearMeSearchBar = (SearchView) mView.findViewById(R.id.nearme_search_component_nearme_edittext);
mNearMeSearchBar.setIconifiedByDefault(false); //Removes Search Hint Icon

要更改可绘制的搜索按钮:

int searchImgId = getResources().getIdentifier("android:id/search_mag_icon", null, null);
ImageView v = (ImageView) mNearMeSearchBar.findViewById(searchImgId);
v.setImageResource(R.drawable.ic_compass);

【讨论】:

【参考方案6】:

您必须像这样自定义SearchView 样式:

<style name="MySearchViewStyle" parent="Widget.AppCompat.SearchView">
    <!-- Search button icon -->
    <item name="searchIcon">@drawable/ic_arrow_back</item>
</style>

然后将其添加到您的AppTheme

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!--   your other colors and styles -->
    <item name="searchViewStyle">@style/MySearchViewStyle</item>
</style>

并使用标签 style 将其应用于您的搜索视图:

<android.support.v7.widget.SearchView
            xmlns:android="http://schemas.android.com/apk/res/android"
            xmlns:app="http://schemas.android.com/apk/res-auto"
            android:id="@+id/searchView"
            android:layout_
            android:layout_
            app:queryHint="@string/search_hint"
            android:focusable="true"
            android:focusableInTouchMode="true"
            style="@style/MySearchViewStyle"
            app:iconifiedByDefault="false" />

希望对你有帮助!

【讨论】:

【参考方案7】:

如果您使用的是 v7 应用兼容库,您可以在主题中轻松更改它。在从 AppCompat 主题扩展的主题中,只需添加如下一行:

<item name="searchViewSearchIcon">@drawable/ic_search</item>

【讨论】:

【参考方案8】:

这些行去掉了放大镜:

    //remove search icon
    mSearchView.setIconifiedByDefault(false);
    ImageView icon = (ImageView) mSearchView.findViewById(android.support.v7.appcompat.R.id.search_mag_icon);
    icon.setVisibility(View.GONE);

【讨论】:

【参考方案9】:

在您的主题风格中包含以下内容:

<style name="YourTheme.Toolbar">
    <item name="searchViewStyle">@style/YourActionBarSearch</item>
    <item name="editTextColor">@color/your_ab_text_color</item>
    <item name="android:textColorHint">@color/your_ab_hint_color</item>
</style>

您现在可以使用searchViewStyle 定义 SearchView 的样式,editTextColor 将设置搜索框中文本的颜色。通过设置android:textColorHint,您还将设置提示的颜色,例如“搜索……”。

<style name="YourActionBarSearch" parent="@style/Widget.Holo.SearchView">
    <item name="searchIcon">@drawable/ic_ab_search</item>
    <item name="queryBackground">@null</item>
    <item name="submitBackground">@null</item>
    <item name="searchHintIcon">@null</item>
    <item name="defaultQueryHint">@null</item>
    <item name="closeIcon">@drawable/ic_ab_small_search_close</item>
</style>

这将或多或少地为您的搜索视图设置样式。字段searchIcon 是操作栏中的图标。 searchHintIcon 字段是搜索字段提示左侧的小图标,这是您在问题中要求的;将其设置为 @null 以删除图标。 closeIcon 字段是搜索字段右侧的关闭图标。

【讨论】:

【参考方案10】:

在searchView组件的xml中添加下一个:

app:searchHintIcon="@null"

【讨论】:

以上是关于Android SearchView 图标的主要内容,如果未能解决你的问题,请参考以下文章

如何更改 SearchView 上的默认图标,以便在 Android 的操作栏中使用?

如何更改SearchView上的默认图标,以便在Android的操作栏中使用?

为 Android TV 应用程序更改 BrowseFragment 的 SearchView 默认图标?

Android SearchView 自定义SearchIcon和字体颜色大小

Android学习笔记(29):搜索框SearchView

Android:Searchview甚至打开其他具有不同ID的菜单项