使用ActionBar选项卡重置ViewPager中的SearchView片段更改
我用ActionBar选项卡实现了两个片段。 我正在使用Sherlock碎片。 当我开始一个片段时,我在操作栏上创建了一个searchview。
问题是:当我搜索第一个片段上的某些内容并且没有关闭搜索视图或删除文本时,我移动到下一个片段,我得到一个折叠的searchview,这很好。 但是当我再次回到我的第一个片段时,我看到一个像以前一样排序的列表,但searchview被折叠。 获取原始列表的唯一方法是单击searchview并关闭它。
当我移动到第二个片段时如何重置第一个片段上的searchview,或者当我到达第一个片段时如何保持searchview打开?
任何一个解决方案都可以。
<menu 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"
>
<item android:id="@+id/action_search"
android:title="search"
android:icon="@drawable/search"
android:orderInCategory="100"
android:showAsAction="always|collapseActionView"
android:actionViewClass="com.actionbarsherlock.widget.SearchView" />
</menu>
这就是我在片段中膨胀的方式
@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater)
{
super.onCreateOptionsMenu(menu, inflater);
inflater.inflate(R.menu.main, menu);
SearchView sv = (SearchView)getActivity().findViewById(R.id.action_search);
sv.setOnQueryTextListener(new OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
//...
return false;
}
@Override
public boolean onQueryTextChange(String newText) {
bindingData.resetData();
bindingData.getFilter().filter(newText.toString());
return false;
}
});
}
对于那些仍然挠头并且无法找到解决方案的人来说,在这里它是如何做到的。 这很简单:
在创建时,只需为您的searchviews分配一个ID(通过创建ids.xml并在其中保留id并在运行时分配它)。 现在,在主选项卡活动的onTabUnselected()方法中,确定searchviews并使用函数setIconified(true)两次(一次删除文本,一次删除搜索视图)。
不要忘记在searchview的onQueryTextChange方法中添加一个空查询字符串检查,它为我创建了一个问题。
Android为您提供了像onCreate
和onDestroy
这样的方法来处理活动以及onCreateOptionsMenu
和onDestoryOptionsMenu
菜单。 您可以使用onDestroyOptionsMenu
方法来清除您的SearchView或实现您的另一个想法。
例如:
@Override
public void onDestroyOptionsMenu() {
super.onDestroyOptionsMenu();
if (searchView != null &&
!searchView.getQuery().toString().isEmpty()) {
searchView.setIconified(true);
searchView.setIconified(true);
}
}
它适合我,祝你好运。
链接地址: http://www.djcxy.com/p/92945.html上一篇: Reset the SearchView on fragment change in ViewPager with ActionBar tabs
下一篇: Creating a SearchView that looks like the material design guidelines