Я разрабатываю приложение в чате, и есть конкретный 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
Создать Coroutine внутри OnBindViewholder создает беспорядок ⇐ Android
Форум для тех, кто программирует под Android
-
Anonymous
1749198763
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>
Подробнее здесь: [url]https://stackoverflow.com/questions/57978714/create-coroutine-inside-onbindviewholder-creates-a-mess[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия