Java 我能';使用getFilter()后不进行排序

Java 我能';使用getFilter()后不进行排序,java,android,listview,Java,Android,Listview,我的java文件是:此文件包含Listview中的搜索和排序,但使用searchbar后排序不起作用,我发现的问题是代码:adapter.getFilter().filter(charSequence)当我删除它时,应用程序工作正常,但未完成筛选。所以问题是那条线。有没有办法在listview中进行搜索和排序 public class MainActivity extends AppCompatActivity { public List<String> galaxies=new A

我的java文件是:此文件包含Listview中的搜索和排序,但使用searchbar后排序不起作用,我发现的问题是代码:adapter.getFilter().filter(charSequence)当我删除它时,应用程序工作正常,但未完成筛选。所以问题是那条线。有没有办法在listview中进行搜索和排序

public class MainActivity extends AppCompatActivity {
public List<String> galaxies=new ArrayList<>();
boolean ascending = true;
/*
- When activity is created.
 */
private Button sortBtn;
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    final ListView lv= (ListView) findViewById(R.id.mListView);

    //REFERENCE MATERIALSEARCHBAR AND LISTVIEW

    MaterialSearchBar searchBar = (MaterialSearchBar)  
    findViewById(R.id.searchBar);
    searchBar.setHint("Search..");


    galaxies.add("Cartwheel");
    galaxies.add("Whirlpool");
    galaxies.add("Andromeda I");
    galaxies.add("Andromeda II");
    galaxies.add("Sombrero");
    galaxies.add("Messier 81");
    galaxies.add("Messier 87");
    galaxies.add("Canis Majos Over-density");
    galaxies.add("Messier 92");
    galaxies.add("Black Eye");
    galaxies.add("Centaurus A");
    galaxies.add("Centaurus B");
    galaxies.add("Milky Way");
    galaxies.add("IC 1011");
    galaxies.add("Star Bust");
    galaxies.add("Hoag's Object");
    galaxies.add("Pinwheel");
    galaxies.add("Triangulum");
    galaxies.add("Cosmos Redshift");
    galaxies.add("Ursa Minor");
    galaxies.add("Virgo Stellar-Stream");

    //ADAPTER
    final ArrayAdapter adapter=new 
    ArrayAdapter(this,android.R.layout.simple_list_item_1,galaxies);
    lv.setAdapter(adapter);

    //SORT
    sortBtn = (Button) findViewById(R.id.sortBtn);

    adapter.notifyDataSetChanged();
    lv.setTextFilterEnabled(true);
    sortBtn.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            if (ascending)
            {
                Collections.sort(galaxies);
                Toast.makeText(getApplicationContext(),galaxies.get(0),
                        Toast.LENGTH_SHORT).show();
            }
            else
            {
                Collections.reverse(galaxies);
                Toast.makeText(getApplicationContext(),galaxies.get(0),
                        Toast.LENGTH_SHORT).show();
            }


            lv.setAdapter(adapter);
            ascending = !ascending;

        }
    });

    //SEARCHBAR TEXT CHANGE LISTENER
    searchBar.addTextChangeListener(new TextWatcher() {
        @Override
        public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {

        }

        @Override
        public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
            //SEARCH FILTER
            adapter.getFilter().filter(charSequence);

        }

        @Override
        public void afterTextChanged(Editable editable) {


        }
    });


    //LISTVIEW ITEM CLICKED
    lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
        @Override
        public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
            Toast.makeText(MainActivity.this, adapter.getItem(i).toString(), Toast.LENGTH_SHORT).show();
        }
    });

 }
}
public类MainActivity扩展了AppCompatActivity{
public List=new ArrayList();
布尔升序=真;
/*
-创建活动时。
*/
专用按钮排序;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Toolbar Toolbar=(Toolbar)findViewById(R.id.Toolbar);
设置支持操作栏(工具栏);
最终ListView lv=(ListView)findViewById(R.id.mListView);
//参考资料搜索栏和列表视图
MaterialSearchBar搜索栏=(MaterialSearchBar)
findviewbyd(R.id.searchBar);
searchBar.setHint(“搜索…”);
添加(“车轮”);
加上(“漩涡”);
星系。加上(“仙女座一号”);
星系。添加(“仙女座II”);
加上(“罩袍”);
加上(“梅西耶81”);
加上(“梅西耶87”);
星系。加上(“犬科动物超过密度”);
加上(“梅西耶92”);
加上(“黑眼”);
星系。添加(“半人马座A”);
星系。加上(“半人马座B”);
星系。加上(“银河系”);
添加(“IC 1011”);
星系。加上(“恒星半身像”);
星系。添加(“霍格天体”);
添加(“风车”);
星系。加上(“三角形”);
星系。加上(“宇宙红移”);
加上(“小熊星座”);
星系。加上(“处女座恒星流”);
//适配器
最终阵列适配器=新
ArrayAdapter(这是android.R.layout.simple\u list\u item\u 1,galaxies);
低压设置适配器(适配器);
//分类
sortBtn=(按钮)findViewById(R.id.sortBtn);
adapter.notifyDataSetChanged();
lv.setTextFilterEnabled(真);
sortBtn.setOnClickListener(新视图.OnClickListener(){
@凌驾
公共void onClick(视图){
if(升序)
{
收藏。分类(星系);
Toast.makeText(getApplicationContext(),galays.get(0),
吐司。长度(短)。show();
}
其他的
{
收藏。反向(星系);
Toast.makeText(getApplicationContext(),galays.get(0),
吐司。长度(短)。show();
}
低压设置适配器(适配器);
升序=!升序;
}
});
//搜索栏文本更改侦听器
addTextChangeListener(新的TextWatcher(){
@凌驾
更改前的公共无效(CharSequence CharSequence,int i,int i1,int i2){
}
@凌驾
public void onTextChanged(CharSequence CharSequence,int i,int i1,int i2){
//搜索过滤器
adapter.getFilter().filter(charSequence);
}
@凌驾
public void PostTextChanged(可编辑){
}
});
//已单击列表视图项
lv.setOnItemClickListener(新的AdapterView.OnItemClickListener(){
@凌驾
公共无效onItemClick(AdapterView AdapterView、View视图、int i、long l){
Toast.makeText(MainActivity.this,adapter.getItem(i).toString(),Toast.LENGTH_SHORT).show();
}
});
}
}
我的xml内容是:

<?xml version="1.0" encoding="utf-8"?>
<!--
- ActivityMain.xml.
- This is a template layout for our MainActivity.
- Root layout tag is CoordinatorLayout from design support library.
- CordinatorLayout is viewgroup that is a superpowered on framelayout.
- CoordinatorLayout is intended for two primary use cases:
As a top-level application decor or chrome layout
As a container for a specific interaction with one or more child views
- Inside our CordinatorLayout we add : AppBarLayout,FloatingActionButton and include content_main.xml.
- AppBarLayout is vertical LinearLayout that implements scrolling features of material design concept.
- It should be a direct child of CordinatorLayout, otherwise alot of features won't work.
- Inside the AppBarLayout we add our toolbar,which we give a blue color.
- Next we add our Material SearchBar which will give us the searchbar.
- We can specify attributes like style and hint.
- We will add our widgets in our content_main.xml, not here as this is a template layout.
- Finally we have a FloatingActionButton, a class that derives from android.support.design.widget.VisibilityAwareImageButton.
Its the round button you see in our user interface.
-->
<android.support.design.widget.CoordinatorLayout 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"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.tutorials.hp.searchbarlistview.MainActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/AppTheme.AppBarOverlay">
        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            app:popupTheme="@style/AppTheme.PopupOverlay" />
        <com.mancj.materialsearchbar.MaterialSearchBar
             app:mt_hint="Custom hint"
            app:theme="@style/AppTheme.PopupOverlay"
            app:mt_maxSuggestionsCount="5"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/searchBar" />
    </android.support.design.widget.AppBarLayout>

    <include layout="@layout/content_main" />

    <Button
        android:id="@+id/sortBtn"
        android:layout_width="100dp"
        android:layout_height="40dp"
        android:layout_centerInParent="true"
        android:layout_gravity="bottom|end|center_horizontal"
        android:background="@color/colorAccent"
        android:text="Sort"
        tools:layout_editor_absoluteX="0dp"
        tools:layout_editor_absoluteY="16dp" />

</android.support.design.widget.CoordinatorLayout>


问题是,当我使用“排序”按钮时,它工作正常,但仅在开始时。当我使用搜索栏和“使用排序”选项时,它将不起作用。

一旦您点击“过滤器”,阵列适配器将维护您的值的单独副本,您对自己的星系列表副本所做的任何更改都不会影响您的列表,请尝试使用此代码对您的值进行排序

adapter.sort(list, new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
    return s1.compareTo(s2);
}
adapter.sort(列表,新比较器(){
@凌驾
公共整数比较(字符串s1、字符串s2){
返回s1.compareTo(s2);
}
}))


这将对适配器维护的副本进行排序

您可以使自定义适配器扩展BaseAdapter,并将列表传递到自定义适配器的构造函数中。 您可以在端部维护列表的两个不同副本。 第一个是原始列表,第二个是传递给适配器构造函数的列表

以下链接将为您提供一个想法:

sure:在传递到适配器之前对
列表进行排序