Как отсортировать просмотр списка с элементами списка просмотра Android? - PullRequest
1 голос
/ 01 октября 2019

У меня есть список, который я заполняю из базы данных. В списке показаны доступные продукты со следующими данными:

  1. Время приготовления пищи
  2. Рейтинг ресторана
  3. Лат / Лонг ресторана
  4. Количество еды.

Теперь я хочу отсортировать список на основе этих четырех элементов. Я использую ArrayList<HashMap<String, String>> и адаптер, расширяющий базовый адаптер.

Я видел много ответов о SO с Collections.sort, но мне не удалось реализовать его в моем коде.

ПРИМЕЧАНИЕ : У меня нет модели данных, определенной для объекта AvailableFood для заполнения arrayList. Вот мой код:

AvailableFood.java

public class AvailableFood extends Fragment {

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
        rootview = inflater.inflate(R.layout.fragment_available_food, container, false);

        mBottomNavigationView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem menuItem) {
                switch (menuItem.getItemId()){
                    case R.id.nav_sort:
                        PopupMenu popup = new PopupMenu(getContext(), rootview.findViewById(R.id.nav_sort));
                        MenuInflater inflater = popup.getMenuInflater();
                        inflater.inflate(R.menu.sort_menu, popup.getMenu());
                        popup.setOnMenuItemClickListener(new PopupMenu.OnMenuItemClickListener() {
                            @Override
                            public boolean onMenuItemClick(MenuItem menuItem) {
                                switch (menuItem.getItemId()){
                                    case R.id.sort_recent: sortAvailableFood("Time");
                                        break;
                                    case R.id.sort_qty: sortAvailableFood("Qty");
                                        break;
                                    case R.id.sort_rating: sortAvailableFood("Rating");
                                        break;
                                    case R.id.sort_distance: sortAvailableFood("Distance");
                                        break;
                                }
                                return true;
                            }
                        });
                        popup.show();

                }
                return false;
            }

        });
        lvAvlFood = rootview.findViewById(R.id.list_avl_food);

        arrListAvlFood = new ArrayList<HashMap<String, String >>();
        arrListLoc = new ArrayList<HashMap<String, String>>();

        return rootview;
    }

    private void sortAvailableFood(String by) {
        switch (by){
            case"Time":
                break;
            case"Qty":case"Qty":
                Collections.sort(arrListAvlFood, new Comparator<HashMap<String, String>>() {
                    @Override
                    public int compare(HashMap<String, String> obj1, HashMap<String, String> obj2) {
                        if( Double.parseDouble(obj1.get(AvailableFood.KEY_QTY)) > Double.parseDouble(obj2.get(AvailableFood.KEY_QTY)) ) {
                            return 1;
                        }
                        else {
                            return 0;
                        }
                    }
                });
                AvlFoodAdapter sortedAdapter = new AvlFoodAdapter(getActivity(),arrListAvlFood);
                lvAvlFood.setAdapter(sortedAdapter);

                break;
            case"Rating":
                break;
            case"Distance":
                break;
        }
    }
}

LoadAllFood.java

class LoadAllFood extends AsyncTask<String, String, String>{

    @Override
    protected String doInBackground(String... strings) {
            List<NameValuePair> params = new ArrayList<NameValuePair>();
            String ngoId = new SessionManager(getContext()).getUserId();
            if(ngoId != null || !ngoId.equals("")) {
                params.add(new BasicNameValuePair("n_id", ngoId));
            }
            JSONObject json = jParser.makeHttpRequest(url_avl_food, "GET", params);

            try {
                int success = json.getInt("success");

                if (success == 1) {

                    jaAvlFood = json.getJSONArray("avl_food");

                    // looping through All Food
                    for (int i = 0; i < jaAvlFood.length(); i++) {
                        JSONObject c = jaAvlFood.getJSONObject(i);


                        String prep_time = c.getString("prep_time");
                        String upload_time = c.getString("upload_time");
                        Double qty = c.getDouble("qty");
                        resName = c.getString("res_name");
                        String lat = c.getString("lat");
                        String longi = c.getString("longi");
                        String rating = c.getString("g_rating");

                        HashMap<String, String> map = new HashMap<String, String>();
                        HashMap<String, String> hmLatLong = new HashMap<String, String>();

                        map.put("f_id", f_id);


                        map.put("prep_time",prep_time);
                        map.put("upload_time",upload_time);
                        map.put("qty",qty.toString());
                        map.put("name",resName);
                        map.put("g_rating", rating);


                        hmLatLong.put("lat",lat);
                        hmLatLong.put("longi",longi);

                        arrListAvlFood.add(map);
                        arrListLoc.add(hmLatLong);
                    }
                } else {

                }
            } catch (JSONException e) {
                e.printStackTrace();
            }
            return null;
    }  
}

1 Ответ

1 голос
/ 01 октября 2019

Создайте класс модели для Food, который будет включать в себя другие элементы данных, а также сделает ваш код более читабельным.

 class Food {
    Integer foodId;
    String preparedAt;
    String uploadedAt;
    String name;
    // other data members

    //constructor


    //setter for food id
    public setFoodId(id){
        this.foodId = id
    }
    //getter for food id
    public getFoodId(){
        return this.foodId
    }


    //setters and getters for other data members

    //toString() method
}

Далее в AsyncTask для LoadAllFoods вы можете сделать что-то вроде:

class LoadAllFood extends AsyncTask<Food, String, String>{
    @Override
    protected String doInBackground(Food... foods) {

    }
}

Теперь все, что вам нужно для просмотра списка, это List<Food>, и вы можете ссылаться на значение preparedAt или любой другой элемент данных в вашем классе адаптера, выполняя что-то вроде: food.getFoodId();

...