Android搜索小部件如何默认在搜索视图中隐藏关闭按钮?

问题描述 投票:9回答:6

我在SearchView中实现了一个android ActionBar。当SearchView获得焦点时,将显示右侧的关闭按钮[x]。我查看了其他Android本机应用程序,例如“联系人”和“ Gmail”。当SearchView获得焦点时,关闭按钮不显示。如何设置我的SearchView的行为方式?

android android-widget searchview
6个回答
14
投票

设置searchView.setIconifiedByDefault(false)将禁用折叠搜索视图,并同时删除关闭按钮。


12
投票

我在android.support.v7.widget.SearchView时遇到了同样的问题,并找到了解决方案。首先,在onCreateOptionsMenu中,您可以获得对SearchView及其关闭按钮的引用:

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

    MenuItem searchItem = menu.findItem(R.id.action_search);
    mSearchView = (SearchView) MenuItemCompat.getActionView(searchItem);

    try {
        Field searchField = SearchView.class.getDeclaredField("mCloseButton");
        searchField.setAccessible(true);
        mSearchCloseButton = (ImageView) searchField.get(mSearchView);
    } catch (Exception e) {
        Log.e(TAG, "Error finding close button", e);
    }
}

现在您可以尝试修改按钮。首先,我尝试使用setVisibility(View.GONE)隐藏关闭按钮,但这不起作用,因为当用户与SearchView进行交互时,SearchView会重置其关闭按钮的可见性。因此,我的解决方案是使用透明的drawable并禁用关闭按钮的单击:

if (mSearchCloseButton != null) {
    mSearchCloseButton.setEnabled(false);
    mSearchCloseButton.setImageDrawable(getResources().getDrawable(R.drawable.transparent));
}

这篇文章对我也有帮助:http://novoda.com/blog/styling-actionbar-searchview

但是,说实话,这很不容易。从https://android.googlesource.com/platform/frameworks/support.git/+/master/v7/appcompat/src/android/support/v7/widget/SearchView.java中获取SearchView源,并创建自己的SearchView版本(执行关闭按钮的隐藏/显示操作)会更加干净。

更新:Google刚刚发布了AppCompat v21,它对SearchView小部件的样式进行了改进:http://android-developers.blogspot.com/2014/10/appcompat-v21-material-design-for-pre.html


7
投票

您也可以使用它来隐藏关闭按钮

ImageView closeBtn = (ImageView) searchView.findViewById(R.id.search_close_btn);
closeBtn.setEnabled(false);
closeBtn.setImageDrawable(null);

6
投票

您可以从SearchView对象(AppCompat v23.2.1)中获得按钮的链接:

searchView = (SearchView) MenuItemCompat.getActionView(menu.findItem(R.id.action_search));
ImageView mCloseButton = (ImageView) searchView.findViewById(android.support.v7.appcompat.R.id.search_close_btn);

然后,您可以为SearchView文本更改分配一个侦听器(SearchView也会更改按钮的可见性,但是此侦听器将在之后执行,并将覆盖这些更改):

searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
    @Override
    public boolean onQueryTextSubmit(String query) {
        return false;
    }

    @Override
    public boolean onQueryTextChange(String newText) {
        mCloseButton.setVisibility(newText.isEmpty() ? View.GONE : View.VISIBLE);
        return false;
    }
});

最后,当SearchView从图标化状态展开时,一个侦听器隐藏图标:

searchView.setOnSearchClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        // hide "x" button if there is no text
        String query = searchView.getQuery().toString();
        mCloseButton.setVisibility(query.isEmpty() ? View.GONE : View.VISIBLE);
    }
});

4
投票

为将来的访客发布。以前的答案很旧,并不容易。您要做的就是通过这种方式将null设置为app:closeIcon app:closeIcon="@null"

  <androidx.appcompat.widget.SearchView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    app:closeIcon="@null"   <!-- This simple solution -->
    app:iconifiedByDefault="false" />

0
投票

使用AndroidXandroid.support.v7.appcompat.R.id.search_close_btn将不起作用

这将解决问题,

app:closeIcon="@null"
© www.soinside.com 2019 - 2024. All rights reserved.