J'utilise la nouvelle bibliothèque de support ListAdapter
. Voici mon code pour l'adaptateur
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)
}
}
}
Je mets à jour l'adaptateur avec
musicViewModel.getAllArtists().observe(this, Observer {
it?.let {
artistAdapter.submitList(it)
}
})
Ma classe de différence
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
}
}
Ce qui se passe, c'est que lorsque submitList est appelé la première fois, l'adaptateur rend tous les éléments, mais lorsque submitList est appelé à nouveau avec des propriétés d'objet mises à jour, il ne rend pas à nouveau la vue qui a changé.
Il redéfinit la vue lorsque je fais défiler la liste, ce qui appelle à son tour bindView()
De plus, j'ai remarqué qu'appeler adapter.notifyDatasSetChanged()
après la soumission de la liste rend la vue avec les valeurs mises à jour, mais je ne veux pas appeler notifyDataSetChanged()
parce que l'adaptateur de liste a des utilitaires de diff intégrés
Quelqu'un peut-il m'aider ?