слышал что так не стоит делать. в таком случае, есть более элегантные способы?
нужно чтобы заново вызвался onBindViewHolder и перерисовались вью
DiffUtils
Разумно использовать DiffUtils. Он сам решит, какие notify вызывать.
ну, мне ж всё нужно перерисовать где можно найти пример с вызовом дифф утилс?
Наверное, в гугле. android diffutils example
не так выразился немного диффутилс же смотрит изменились ли элементы, а у меня менятся не порядок или контент списка, а вью (меняется visibility вьюшки внутри каждого айтема) .
А чой-то оно меняется? Чудесным образом силой мысли или по причине изменения данных, которые относятся к этому айтему? Если первое, то хз, а если второе - то diffutils.
массовый селект по long click на элемент один выбирается, на остальных рисуется чекбокс чтобы можно было нажать на них и выбрать несколько элементов
Вероятно, в данных у айтемов должно быть предусмотрено состояние "выбираемости", чтобы они могли показать чекбокс. Иначе у вас при скролле все чекбоксы и их почеканность потеряются.
да, и нужно будет вызвать onBindViewHolder заново, как я понял
Он сам вызовется при скролле или notify
поэтому изначально я и хотел сделать notifyItemRangeChanged на все элементы (выглядит как костыль) но другие варианты - заново присвоить список или адаптер - еще бо́льшие костыли
Кликнули айтем - обновили его данные в массиве данных адаптера - вызвали notify - айтем обновился в соответствии со своими текущими данными.
*обновили его (сделали видимым drawable чекбокс checked) и все остальные элементы тоже (чекбокс unchecked), а по клику на второй и тд - уже обновление по одному тогда получается только submitList делать
Если знаешь что именно перерисовывать - вызываешь для него notify.... конкретного айтема или события Если вообще все или сам непонял что а разбираться некогда - notifyDatasetChanged
Если не сохранять эти состояния отдельно в данных, то при скролле они превратятся в тыкву.
Обсуждают сегодня