Создать Coroutine внутри OnBindViewholder создает беспорядокAndroid

Форум для тех, кто программирует под Android
Ответить
Anonymous
 Создать Coroutine внутри OnBindViewholder создает беспорядок

Сообщение Anonymous »

Я разрабатываю приложение в чате, и есть конкретный API, поэтому я должен реализовать их определенным образом. Например (и случай, когда у меня есть проблема ...) < /p>

Когда мне нужно отобразить изображение, API говорит, что мне нужно разделить изображение небольшими кусками и сохранить их в виде сообщения с контентом Bytearray. Существует также заголовок, что его тело - это сообщения FileChunks. Таким образом, в Recyclerview внутри OnBindViewholder, когда я вижу сообщение с файлом заголовка (msgtype == 1), я запускаю Coroutine, чтобы получить сообщения Chunkfile с помощью идентификаторов, построить файл, а затем переключаться на MainDispatcher и, следовательно, изображение с Glide с использованием Bitmapfactory.DecodeByTearRay. Код показан ниже < /p>

messageItem.message?.msgType == MSG_TYPE_FILE -> {
holder.sntBody.text = "Loading file"

val fileInfo = Gson().fromJson(URLDecoder.decode(messageItem.message?.body, "UTF-8"), FileInformation::class.java)

job = chatRoomAdapterScope.launch(Dispatchers.IO) {
// i get the messageIds of the chunks from Header message
val segSequence = fileInfo.seg.split(",").map { it.toLong() }

// i get the fileChunks from Database
val fileChunks = AppDatabase.invoke(mContext).messageDao().getMessageById(segSequence)
val compactFile = ByteArrayOutputStream()

// Reconstruct the file
for (chunk in fileChunks)
compactFile.write(Base64.decode(chunk.fileBody, Base64.DEFAULT))

withContext(Dispatchers.Main) {
val bitmapOptions = BitmapFactory.Options().apply {
inSampleSize = 8
}

Glide.with(mContext).asBitmap()
.load(BitmapFactory.decodeByteArray(compactFile.toByteArray(), 0, compactFile.size(), bitmapOptions)!!)
.fitCenter()
.into(object : SimpleTarget() {
override fun onResourceReady(resource: Bitmap, transition: Transition?) {
holder.sntImageView.setImageBitmap(resource)
holder.sntImageView.visibility = View.VISIBLE
}
})
holder.sntBody.text = fileInfo.filename
}
}
}
< /code>

Моя проблема заключается в том, что когда я быстро прокручиваю изображение, которое должно быть загружено в элемент, появляется в другом элементе. Мое первое предположение состоит в том, что коратика, которая началась с определенного элемента, не завершилась, как только элемент был переработан, поэтому, когда Coroutine закончила, у него была ссылка на новый элемент, поэтому я добавил
holder.itemview.addonattachstatechangelistener, как прокомментировали некоторые люди. Однако я не работал.
Есть ли представление о том, почему это может произойти, и если существует лучшая реализация Proccess в соответствии с конкретным API ...? < /P>

Подробнее здесь: https://stackoverflow.com/questions/579 ... tes-a-mess
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»