Estou usando a nova biblioteca de suporte ListAdapter
. Aqui está meu código para o adaptador
class ArtistsAdapter : ListAdapter<Artist, ArtistsAdapter.ViewHolder>(ArtistsDiff()) {
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
return ViewHolder(parent.inflate(R.layout.item_artist))
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
holder.bind(getItem(position))
}
class ViewHolder(view: View) : RecyclerView.ViewHolder(view) {
fun bind(artist: Artist) {
itemView.artistDetails.text = artist.artistAlbums
.plus(" Albums")
.plus(" \u2022 ")
.plus(artist.artistTracks)
.plus(" Tracks")
itemView.artistName.text = artist.artistCover
itemView.artistCoverImage.loadURL(artist.artistCover)
}
}
}
Estou atualizando o adaptador com
musicViewModel.getAllArtists().observe(this, Observer {
it?.let {
artistAdapter.submitList(it)
}
})
Minha classe diff
class ArtistsDiff : DiffUtil.ItemCallback<Artist>() {
override fun areItemsTheSame(oldItem: Artist?, newItem: Artist?): Boolean {
return oldItem?.artistId == newItem?.artistId
}
override fun areContentsTheSame(oldItem: Artist?, newItem: Artist?): Boolean {
return oldItem == newItem
}
}
O que está acontecendo é quando submitList é chamado na primeira vez que o adaptador renderiza todos os itens, mas quando submitList é chamado novamente com propriedades de objeto atualizadas, ele não renderiza novamente a visualização que foi alterada.
Ele renderiza novamente a visualização conforme eu rolar a lista, que por sua vez chama bindView()
Além disso, percebi que chamar adapter.notifyDatasSetChanged()
após enviar lista renderiza a visualização com valores atualizados, mas não quero chamar notifyDataSetChanged()
porque o adaptador de lista tem utilitários diff integrados
Alguém pode me ajudar aqui?
ArtistsDiff
e, portanto, à implementação deArtist
si mesmo.