У меня есть 3 столбца ListView с данными из базы данных SQLite и окно Seachview.я создал пользовательские данные.Поиск не выполнен должным образом - PullRequest
0 голосов
/ 10 сентября 2018

Я создал MultiColumn ListView с SearchView над ним.Он извлекает данные из базы данных SQLite и отображается в виде списка.Я создал пользовательский ArrayAdapter и класс Java.Однако выходные данные из моего SearchView в моем представлении списка пользовательских массивов из 3 столбцов не возвращают правильные данные, т.е. они не фильтруются правильно.Я перепробовал все, чтобы понять, в чем может быть проблема, и занимался этим последние 3 дня.Я использую QueryTextChangeListerner.Будем благодарны за любую помощь, так как я нахожусь в узком месте в разработке моего приложения.

MainActivity.java:

        mSearchView = (SearchView) findViewById(R.id.search_view);
        listView = (ListView) findViewById(R.id.list_view);

        controller = new ResturantsDbHelper(this);

        userList = new ArrayList<>();

        Cursor resturantdata = controller.getResturantList();

        int numRows =resturantdata.getCount();
        if (numRows == 0) {
            Toast.makeText(SearchResturantListingX.this,"No Resturants matching your selection criteria",Toast.LENGTH_LONG).show();
        }
        else {
            while (resturantdata.moveToNext()) {
                user = new User(resturantdata.getString(1),resturantdata.getString(2),resturantdata.getString(3),resturantdata.getString(4),resturantdata.getString(5));

                userList.add(user);
            }
            //FINISH Populating the array variable with the string data from SQLIte database

            adapter = new FiveColumn_ListAdapter(this,R.layout.activity_search_main3_resturant_list,userList);

            listView.setAdapter(adapter);
        }

        listView.setTextFilterEnabled(true);
        setupSearchView();
    }

    private void setupSearchView() {
        mSearchView.setIconifiedByDefault(false);
        mSearchView.setOnQueryTextListener(this);
        mSearchView.setSubmitButtonEnabled(true);
        mSearchView.setQueryHint("Search Here By Name");
    }

    @Override
    public boolean onQueryTextSubmit(String query) {
        return false;
    }

    @Override
    public boolean onQueryTextChange(String newText) {
        adapter.getFilter().filter(newText);
        return false;
    }
}

Вот мой класс Java, который определяет мои ListItems:

public class User {
    private String resturantName;
    private String resturantType;
    private String resturantLocation;

    public User (String resturantName, String resturantType, String resturantLocation, String rOpening, String rClosing){
        super();
        this.resturantName = resturantName;
        this.resturantType = resturantType;
        this.resturantLocation = resturantLocation;
    }

    public String getResturantName() {
        return resturantName;
    }

    public void setResturantName (String resturantName) {
        this.resturantName = resturantName;
    }

    public String getResturantType() {
        return resturantType;
    }

    public void setType (String resturantType) {
        this.resturantType = resturantType;
    }

    public String getResturantLocation() {
        return resturantLocation;
    }

    public void setLocation (String resturantLocation) {
        this.resturantLocation = resturantLocation;
    }

    public User(String resturantName, String type, String location) {
        super();
        this.resturantName = resturantName;
    }

    @Override
    public String toString() {
        return  resturantName + " ";  
    }
}

Вот мой пользовательский адаптер:

public class FiveColumn_ListAdapter extends ArrayAdapter<User> {

    private LayoutInflater mInflater;
    private ArrayList<User> users;
    private int mViewResourceId;

    public FiveColumn_ListAdapter(Context context, int textViewResourceId, ArrayList<User> users) {
        super(context,textViewResourceId,users);
        this.users = users;
        mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        mViewResourceId = textViewResourceId;
    }

    public View getView(int position, View convertView, ViewGroup parents) {
        convertView = mInflater.inflate(mViewResourceId,null);

        User user =users.get(position);

        if (user != null) {
            TextView name=(TextView)convertView.findViewById(R.id.resturantName);
            TextView type=(TextView)convertView.findViewById(R.id.resturantType);
            TextView location=(TextView)convertView.findViewById(R.id.resturantLocation);

            if(name !=null) {
                name.setText((user.getResturantName()));
            }

            if(type !=null) {
                type.setText((user.getResturantType()));
            }

            if(location !=null) {
                location.setText((user.getResturantLocation()));
            }

        }
        return convertView;
    }
}

Ответы [ 2 ]

0 голосов
/ 11 сентября 2018

FiveColumn_ListAdapter должен реализовать android.widget.Filterable

затем добавьте эти коды к FiveColumn_ListAdapter:

public class FiveColumn_ListAdapter extends ArrayAdapter<User> 
                                implements android.widget.Filterable {

private LayoutInflater mInflater;
private ArrayList<User> users;// this is filtered users a subset of AllUsers
private int mViewResourceId;
private ArrayList<User> AllUsers;// AllUsers is users without any filter

public FiveColumn_ListAdapter(Context context, int textViewResourceId, 
                                             ArrayList<User> users, String initialQuery) {
    super(context,textViewResourceId,users);
    this.AllUsers = users;
    mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    mViewResourceId = textViewResourceId;
    getFilter().filter(initialQuery);// perform fiter to populate users filter may be empty String
}

    @Override
    public Filter getFilter() {
        return new Filter() {
            @Override
            protected FilterResults performFiltering(CharSequence query) {

                FilterResults filterResults = new FilterResults();
                if(AllUsers == null || AllUsers.size() == 0){
                     filterResults.count = 0;
                     filterResults.values = null;
                     return filterResults;
                }
                ArrayList<User> results = new ArrayList<>();
                for (User user : AllUsers) {
                      if(query.toString().equals(user.getResturantName())// do any filtering here
                         results.add(user);
                }
                filterResults.count = results.size();
                filterResults.values = results;
                return filterResults;
            }
            ///////////////////////////////
            @Override
            protected void publishResults(CharSequence constraint, FilterResults results) {
                users = results.values// 
            }
        };
    }
0 голосов
/ 11 сентября 2018
  1. Сначала вам нужно изменить коллекцию предметов, чтобы их сортировали все время.Один из примеров.

    private Set<User> users; ..... users = new SortedSet<>();

  2. Измените реализацию User Objects на интерфейс Comparable.Напримерниже.

      class Movie implements Comparable<Movie> 
     { 
    private double rating; 
    private String name; 
    private int year; 
    
    // Used to sort movies by year 
    public int compareTo(Movie m) 
    { 
        return this.year - m.year; 
    } 
    
    // Constructor 
    public Movie(String nm, double rt, int yr) 
    { 
        this.name = nm; 
        this.rating = rt; 
        this.year = yr; 
    } 
    
    // Getter methods for accessing private data 
    public double getRating() { return rating; } 
    public String getName()   {  return name; } 
    public int getYear()      {  return year;  } 
    

    }

Затем вы можете настроить всю свою сортировку, как вы ожидаете в описанных выше методах compareTo.См. Больше информации о Comparable Интерфейс.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...