嗨,我想通过SearchView小工具在我的应用程序中搜索用户。当SearchWidget激活时,我想在相同XML布局的ListView上面的ViewPager中显示建议的用户名。我使用了下面的xml
<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >    
<ListView
    android:id="@+id/searched_friends_list"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:divider="@color/list_divider"
    android:dividerHeight="1dp"
    android:layout_marginLeft="15dp"
    android:layout_marginRight="15dp"
    android:visibility="gone"
    android:listSelector="@drawable/list_row_selector" />       
<android.support.v4.view.ViewPager
    android:id="@+id/pager"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >
</android.support.v4.view.ViewPager>
在代码中,我看到了ListView来向用户展示。
@Override
public boolean onQueryTextChange(String newText) {
    friendListView.setVisibility(View.VISIBLE);
    if (TextUtils.isEmpty(newText)) {
        friendListView.clearTextFilter();
    } else {
        friendListView.setFilterText(newText.toString());
    }
    return true;
}它不显示ListView

但是当我添加以下代码时
@Override
public boolean onQueryTextChange(String newText) {
    friendListView.setVisibility(View.VISIBLE);
    viewPager.setVisibility(View.GONE);
    if (TextUtils.isEmpty(newText)) {
        friendListView.clearTextFilter();
    } else {
        friendListView.setFilterText(newText.toString());
    }
    return true;
}它显示了以下输出

但我希望ListView高于ViewPager。提前谢谢。
发布于 2014-10-22 19:34:56
如果你想让你的ListView实时显示结果,这是用户在searchView中的建议--在你的适配器中使用过滤器。
添加到适配器:
ArrayList<full_data> adapterDataList = new ArrayList<full_data>();
ArrayList<filtered_data> mFilteredDataList = new ArrayList<filtered_data>(listOR);
Filter mFilter = new Filter() {
@Override
protected FilterResults performFiltering(CharSequence searchTerm) {
Locale locale = Locale.getDefault();
FilterResults results = new FilterResults();
if ((searchTerm null) || (searchTerm.length() 0)) {
ArrayList<String> searchList = new ArrayList<String>(adapterDataList);
results.values = searchList;
results.count = searchList.size();
} else {
final String searchTermString = searchTerm.toString().toLowerCase(locale);
final String[] words = searchTermString.split(" ");
final int wordCount = words.length;
final ArrayList<String> newValues = new ArrayList<String>();
for (final String value : adapterDataList) {
                    if (value == null) {
                        continue;
                    }
                    final String valueText = value.toLowerCase(locale);
for (int k = 0; k < wordCount; k++) {
                        if (valueText.contains(words[k])) {
                            newValues.add(value);
                            break;
                        }
                    }
                }
                results.values = newValues;
                results.count = newValues.size();
            }
            return results;
        }
@Override
        protected void publishResults(CharSequence constraint, FilterResults results) {
            mFilteredDataList = (ArrayList<String>)results.values;
            notifyDataSetChanged();
        }
    };
public Filter getFilter(){ return mFilter; }
to SearchView's TextChangedListener:
@Override
public void afterTextChanged(Editable searchText) {
mAdapter.getFilter().filter(searchText);
}我认为它应该工作得很好。
https://stackoverflow.com/questions/26500864
复制相似问题