Android ListView не очищается даже после удаления всех элементов

UPDATE : I am able to replicate this issue every time on my Galaxy S2 (with and without debugging mode), but never on the Emulator!

Я использую контекстное меню в ListView (который использует пользовательскую реализацию CursorAdapter ), чтобы пользователь мог выбрать опцию « Удалить все ». Когда этот параметр выбран, все элементы, отображаемые в списке, должны быть удалены постоянно из базы данных, после чего следует вызвать changeCursor (..) на адаптере, чтобы заставить список обновляться ,

Однако происходит то, что даже после удаления записей из базы данных и вызова changeCursor (..) элементы видны. Только разделители элементов исчезают. Только после того, как я прикоснусь к списку, очистите эти элементы.

When the user activates the context menu : http://i.stack.imgur.com/ivFvJ.png

After deletion from database AND calling changeCursor(..) : http://i.stack.imgur.com/CX6BM.png

У меня возникла другая проблема с ListView ( элементы списка ListView на Android во время прокрутки ), и я использую тот же ListView, так что, возможно, проблемы связаны? Есть ли какой-то шаг, чтобы заставить ListView перерисовывать после обновления базы данных? Или это не происходит автоматически из-за ошибки в том, как я реализовал решение? Заранее спасибо!

Here's the xml for the ListView


Here's the newView(..) method of my custom CursorAdapter

public View newView(Context context, Cursor cursor, ViewGroup parent) {
    LayoutInflater inflater = LayoutInflater.from(parent.getContext());
    View view = inflater.inflate(R.layout.view_list_item, parent, false);
    return view;
}

The bindView(..) method of my CursorAdapter

public void bindView(View view, Context context, Cursor cursor) {

        TextView whatTextView = (TextView) view.findViewById(R.id.item_what_text);
        whatTextView.setText(cursor.getString(1));
        TextView whenTextView = (TextView) view.findViewById(R.id.item_when_text);


        if(cursor.getInt(9) != 0)//DONE_FLAG = 1 (completed)
        {
            //Arrow visibility
            ImageView arrow = (ImageView)view.findViewById(R.id.list_item_arrow);
            arrow.setVisibility(View.INVISIBLE);

            //Text color
            whatTextView.setTextColor(Color.LTGRAY);
            whenTextView.setTextColor(Color.LTGRAY);

            //WHEN text
            whenTextView.setText(TimeCalculationHelper.getCompletedTimeString(cursor.getLong(2)));
        }
        else//DONE_FLAG = 0
        {
            //Arrow visibility
            ImageView arrow = (ImageView)view.findViewById(R.id.list_item_arrow);
            arrow.setVisibility(View.VISIBLE);

            //Text color
            whatTextView.setTextColor(Color.BLACK);
            whenTextView.setTextColor(Color.BLACK);

            //WHEN text
            whenTextView.setText(TimeCalculationHelper.getTimeRemainingString(cursor.getLong(2)));


        }
}

Here's my onContextItemSelected(..) method from the Activity that contains the ListView

public boolean onContextItemSelected(MenuItem item)
    {
        AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo();
        ListView allRemindersList = (ListView)findViewById(R.id.all_reminders_list);

        switch (item.getItemId()) {
        case R.id.delete_item:
            //Delete the selected reminder from the database
            databaseHelper.deleteRowByID(info.id);

            //Refresh the main activity list
            ((ActiveRemindersAdapter) allRemindersList.getAdapter()).changeCursor(databaseHelper.getAllRemindersForList());
            return true;

        case R.id.delete_done:
            //Delete all reminders with DONE_FLAG = 1
            databaseHelper.deleteDoneReminders();

            //Refresh the main activity list
            ((ActiveRemindersAdapter) allRemindersList.getAdapter()).changeCursor(databaseHelper.getAllRemindersForList());
        }
        return false;
    }
0
nl ja de
Никита прав, и лучше использовать CursorAdapter из библиотеки поддержки и вызывать swapCursor() вместо changeCursor ()
добавлено автор Yaroslav Mytkalyk, источник
Попробуйте добавить ((ActiveRemindersAdapter) allRemindersList.getAdapter ()). NotifyDataSetChanged() вызов после изменения курсора.
добавлено автор Nikita Beloglazov, источник
android listview"> stackoverflow.com/questions/2250770/…
добавлено автор Saifuddin Sarker, источник
@SaifuddinSarker, я пробовал invalidateViews() тоже, но это не сработало для меня.
добавлено автор Pritin Tyagaraj, источник

1 ответы

Вызовите notifyDataSetChanged() на свой адаптер после изменения курсора, чтобы перезагрузить представления. И лучше использовать CursorAdapter из

Обновленный ответ. notifyDataSetChanged() - это метод BaseAdapter (из которого расширяется CursorAdapter), который заставляет перезагружать представления.
добавлено автор Yaroslav Mytkalyk, источник
@PritinTyagaraj Выполняете ли вы запрос после удаления, прежде чем менять курсор? Вы уверены, что курсор, который вы установили, пуст? Выйдите из cursor.getCount() и посмотрите, сколько строк содержит.
добавлено автор Yaroslav Mytkalyk, источник
Вы пробовали cursor.getCount ()? Это пусто или нет? Если нет - тогда это проблема ListView, но проблема с БД.
добавлено автор Yaroslav Mytkalyk, источник
@PritinTyagaraj Я помню странный рендеринг с вкладками на этом устройстве. Попробуйте добавить в список ListView андроид: background = "# ffffffff". И после замены вызова курсора invalidate() в ListView.
добавлено автор Yaroslav Mytkalyk, источник
Спасибо за ответ. notifyDataSetChanged() ведет себя иначе, чем вызов в changeCursor() ? Будет проверять и проверять, разрешает ли она мою проблему. И я только нацелен на ICS и новые устройства.
добавлено автор Pritin Tyagaraj, источник
Спасибо, но я попробовал позвонить notifyDataSetChanged() после changeCursor() . Я также попытался называть swapCursor() . У меня все еще есть точно такая же проблема.
добавлено автор Pritin Tyagaraj, источник
Да, я обеспечил то же самое. Метод databaseHelper.getAllRemindersForList() фактически выполняет запрос SELECT и возвращает Cursor для результата. Еще одна странная вещь, которую я заметил, что я не могу воспроизвести ее в эмуляторе, но я могу воспроизводить ее каждый раз на своей Galaxy S2 (с режимом отладки и без него)
добавлено автор Pritin Tyagaraj, источник
Извиняюсь, если мой вопрос не ясен (мне не разрешено размещать более двух изображений). Пожалуйста, сравните первый скриншот (перед удалением - ListView имеет разделители), а второй скриншот (после удаления и notifyDataSetChange() - только разделители исчезают). После удаления, когда я касаюсь любого места в списке, удаленные элементы удаляются с экрана. Это, безусловно, проблема с ListView .
добавлено автор Pritin Tyagaraj, источник
Mobile Dev Jobs — вакансии и аналитика
Mobile Dev Jobs — вакансии и аналитика
6 187 участник(ов)

Публикуем вакансии и запросы на поиск работы по направлению iOS, Android, Xamarin и т.д. ВАЖНО: Правила публикации и правила канала: Ссылка – https://telegra.ph/Pravila-oformleniya-vakansij-i-rezyume-11-09-2

Android Developers
Android Developers
4 476 участник(ов)

Общаемся на темы, посвященным Android-разработке, SDK, Kotlin, Realm и т.д.

Android Architecture
Android Architecture
2 186 участник(ов)

Русскоязычный чат по архитектуре в андроид приложениях. Подробнее: http://telegra.ph/Android-Architecture-12-24

rus-speaking/android
rus-speaking/android
1 705 участник(ов)

Основной чат по Android разработке (вопрос-ответ). ПРАВИЛА: bit.ly/andr-rules. NEWS: bit.ly/AnrdResId ЧАТЫ: Основной: bit.ly/andr-main IDE, сборка, Git, сервисы: bit.ly/andr-tools Оффтоп: bit.ly/andr-offtop Конференции, события: bit.ly/andr-events Вакансии, найм: bit.ly/andr-job Архитектура: bit.ly/andr-patterns Rx: bit.ly/andr-rx Тестирование: bit.ly/andr-test Kotlin: bit.ly/andr-kotlin Хаmarin: bit.ly/andr-xamarin За мат, спам, агрессию, предложения о работе, оффтоп в этом канале - бан на сутки и более ☢☢☢

Android Dev Подкаст
Android Dev Подкаст
1 325 участник(ов)

Комната для обсуждения Android Dev подкаста apptractor.ru/AndroidDev/ Общее обсуждение Android: https://t.me/android_ru Остальные чаты про Android: http://t.me/devChats Наши новости https://t.me/androiddevpodcast_news

Android Guards
Android Guards
602 участник(ов)

Обсуждение любых вопросов касающихся безопасности Android. - Защита системы и приложений - Уязвимости и эксплойты - Вредоносное ПО - Копание в кишках системы и приложений (RE)

Android JOB
Android JOB
466 участник(ов)

Публикуем вакансии и запросы на поиск работы по направлению Android (full-time, part-time, remote и разовые подработки)

AndroidDev :: Разработка. It's Android time now!
AndroidDev :: Разработка. It's Android time now!
458 участник(ов)

It's Android time now! Чат разработчиков Android. Вакансии, резюме и информацию о митапах размещать можно. Публикацию скрытой и явной рекламы ваших каналов и сайтов после получения разрешения от @olegushakov

Aandroid Talks!
Aandroid Talks!
212 участник(ов)

Чат об общих вопросах по ОС Android. Чат для разработки под андроид - pro.android: https://t.me/joinchat/AAAAAEKIFKnmRT9cMebb9w

Android Rus
Android Rus
68 участник(ов)