Я не могу удалить элемент из общих настроек - PullRequest
1 голос
/ 13 марта 2020

У меня есть список элементов в навигационном окне, которые добавляются программно - и я сохраняю и восстанавливаю их с помощью общих настроек, все работает нормально. Но проблема в том, что я не могу удалить элемент из общих настроек. Я получаю индекс элемента с помощью щелкнул заголовок текущего элемента - код работает нормально - позиция элемента получена правильно, но не удалена из общих настроек, ничего не работает. Что я могу сделать, чтобы решить эту проблему?

Это мой код:

    private void saveData() {
        SharedPreferences sharedPreferences = getSharedPreferences(SHARED_PREF_LIST_KEY, MODE_PRIVATE);
        SharedPreferences.Editor editor = sharedPreferences.edit();
        Gson gson = new Gson();
        String json = gson.toJson(navItems);
        editor.putString(SHARED_PREF_LIST_KEY_ITEM, json);
        editor.apply();
    }

    private void loadData() {
        SharedPreferences sharedPreferences = getSharedPreferences(SHARED_PREF_LIST_KEY, MODE_PRIVATE);
        Gson gson = new Gson();
        String json = sharedPreferences.getString(SHARED_PREF_LIST_KEY_ITEM, null);
        Type type = new TypeToken<ArrayList<NavItem>>() {
        }.getType();
        navItems = gson.fromJson(json, type);
        if (navItems == null) {
            navItems = new ArrayList<>();
        }
    }

    private void deleteData(NavItem navItem) {
        SharedPreferences sharedPreferences = getSharedPreferences(SHARED_PREF_LIST_KEY, MODE_PRIVATE);
        Gson gson = new Gson();
        String json = sharedPreferences.getString(SHARED_PREF_LIST_KEY_ITEM, null);
        Type type = new TypeToken<ArrayList<NavItem>>() {
        }.getType();
        navItems = gson.fromJson(json, type);
        if (navItems != null) {
            navItems.remove(navItem);
                        Toast.makeText(this, "List " + navItem.getName() + " 
                                          deleted ", Toast.LENGTH_SHORT).show();

            saveData(); // save updated data to shared preferences
        }
    }




           int position = navViewArray.findItemString(checkItemTitle);
                                Toast.makeText(this, "position " + position, 
                                                 Toast.LENGTH_SHORT).show();

               NavItem navItem = navItems.get(position);
                deleteData(navItem);



     public class NavItem {
       private String name;

       public NavItem(String name) {
        this.name = name;
    }

       public String getName() {
        return name;
    }
}

     public class NavViewArray {
       private List<NavItem> navItems;

       public NavViewArray(List<NavItem> items) {
        this.navItems = new ArrayList<>(items);
    }

       public int findItemString(String itemName) {
        for (int i = 0; i < navItems.size(); i++) {
            NavItem navItem = navItems.get(i);
            if (itemName.equals(navItem.getName())) {
                return i;
            }
        }
        return -1;
    }

}

1 Ответ

1 голос
/ 13 марта 2020

Чтобы иметь возможность найти элемент в List, используя сам элемент, вам нужно реализовать equals и hashcode.

Чтобы эта строка кода работала navItems.remove(navItem); Вам нужен класс NavItem для переопределить equals и hashcode

то есть здесь:

public class NavItem {
   private String name;

   public NavItem(String name) {
      this.name = name;
   }

   public String getName() {
      return name;
   }

   // ADD THE BELOW

   @Override
   public boolean equals(NavItem other) {
        return name.equals(other.name);
   }

   @Override
   public int hashcode() {
       return name.hashcode();
   }

}

Это очень простой эквивалент и хэш-код, вы можете использовать IDE для генерации ваших равных и хэш-код, который поможет лучше учесть все поля.

https://www.jetbrains.com/help/idea/generate-equals-and-hashcode-wizard.html


Вы также можете проверить, что элемент был удален, как удаленный элемент возвращается:

NavItem removed= navItems.remove(navItem);
Toast.makeText(this, "List " + removed.getName() + "deleted ",b Toast.LENGTH_SHORT).show();
...