From a1b88db890ca77e9212c3d2c495b675ce871e7fa Mon Sep 17 00:00:00 2001 From: Alexander Maryanovsky Date: Thu, 13 Jun 2024 14:51:57 +0300 Subject: [PATCH] Fix `DesktopImageStorage` to store images by id, rather than by the `PictureData.Camera` itself (#4963) --- .../kotlin/example/imageviewer/Dependencies.kt | 1 + .../example/imageviewer/DesktopImageStorage.kt | 18 ++++++++---------- .../imageviewer/view/ImageViewer.desktop.kt | 2 +- .../imageviewer/storage/IosImageStorage.ios.kt | 4 +--- 4 files changed, 11 insertions(+), 14 deletions(-) diff --git a/examples/imageviewer/shared/src/commonMain/kotlin/example/imageviewer/Dependencies.kt b/examples/imageviewer/shared/src/commonMain/kotlin/example/imageviewer/Dependencies.kt index 6117af6fcc9..0a70b52de38 100644 --- a/examples/imageviewer/shared/src/commonMain/kotlin/example/imageviewer/Dependencies.kt +++ b/examples/imageviewer/shared/src/commonMain/kotlin/example/imageviewer/Dependencies.kt @@ -39,6 +39,7 @@ abstract class Dependencies { } override fun saveImage(picture: PictureData.Camera, image: PlatformStorableImage) { + pictures.add(0, picture) imageStorage.saveImage(picture, image) } diff --git a/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/DesktopImageStorage.kt b/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/DesktopImageStorage.kt index f25b0593aa7..ee26308365e 100644 --- a/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/DesktopImageStorage.kt +++ b/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/DesktopImageStorage.kt @@ -1,6 +1,5 @@ package example.imageviewer -import androidx.compose.runtime.snapshots.SnapshotStateList import androidx.compose.ui.graphics.ImageBitmap import androidx.compose.ui.graphics.toAwtImage import androidx.compose.ui.graphics.toComposeImageBitmap @@ -13,25 +12,24 @@ private const val maxStorableImageSizePx = 2000 private const val storableThumbnailSizePx = 200 class DesktopImageStorage( - private val pictures: SnapshotStateList, private val ioScope: CoroutineScope ) : ImageStorage { - private val largeImages = mutableMapOf() - private val thumbnails = mutableMapOf() + private val largeImages = mutableMapOf() + private val thumbnails = mutableMapOf() override fun saveImage(picture: PictureData.Camera, image: PlatformStorableImage) { if (image.imageBitmap.width == 0 || image.imageBitmap.height == 0) { return } ioScope.launch { - largeImages[picture] = image.imageBitmap.fitInto(maxStorableImageSizePx) - thumbnails[picture] = image.imageBitmap.fitInto(storableThumbnailSizePx) - pictures.add(0, picture) + largeImages[picture.id] = image.imageBitmap.fitInto(maxStorableImageSizePx) + thumbnails[picture.id] = image.imageBitmap.fitInto(storableThumbnailSizePx) } } override fun delete(picture: PictureData.Camera) { - // For now, on Desktop pictures saving in memory. We don't need additional delete logic. + largeImages.remove(picture.id) + thumbnails.remove(picture.id) } override fun rewrite(picture: PictureData.Camera) { @@ -39,11 +37,11 @@ class DesktopImageStorage( } override suspend fun getThumbnail(picture: PictureData.Camera): ImageBitmap { - return thumbnails[picture]!! + return thumbnails[picture.id]!! } override suspend fun getImage(picture: PictureData.Camera): ImageBitmap { - return largeImages[picture]!! + return largeImages[picture.id]!! } } diff --git a/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/view/ImageViewer.desktop.kt b/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/view/ImageViewer.desktop.kt index ccf93f9aefe..ff7800d460b 100755 --- a/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/view/ImageViewer.desktop.kt +++ b/examples/imageviewer/shared/src/desktopMain/kotlin/example/imageviewer/view/ImageViewer.desktop.kt @@ -104,7 +104,7 @@ private fun getDependencies( toastState.value = ToastState.Shown(text) } } - override val imageStorage: DesktopImageStorage = DesktopImageStorage(pictures, ioScope) + override val imageStorage: DesktopImageStorage = DesktopImageStorage(ioScope) override val sharePicture: SharePicture = object : SharePicture { override fun share(context: PlatformContext, picture: PictureData) { // On Desktop share feature not supported diff --git a/examples/imageviewer/shared/src/iosMain/kotlin/example/imageviewer/storage/IosImageStorage.ios.kt b/examples/imageviewer/shared/src/iosMain/kotlin/example/imageviewer/storage/IosImageStorage.ios.kt index 59b0d7c1be5..b84d46d13c0 100644 --- a/examples/imageviewer/shared/src/iosMain/kotlin/example/imageviewer/storage/IosImageStorage.ios.kt +++ b/examples/imageviewer/shared/src/iosMain/kotlin/example/imageviewer/storage/IosImageStorage.ios.kt @@ -14,7 +14,6 @@ import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.IO import kotlinx.coroutines.launch import kotlinx.coroutines.withContext -import kotlinx.serialization.decodeFromString import kotlinx.serialization.encodeToString import kotlinx.serialization.json.Json import platform.CoreGraphics.CGRectMake @@ -36,7 +35,7 @@ private const val storableThumbnailSizePx = 180 private const val jpegCompressionQuality = 60 class IosImageStorage( - private val pictures: SnapshotStateList, + pictures: SnapshotStateList, private val ioScope: CoroutineScope ) : ImageStorage { @@ -77,7 +76,6 @@ class IosImageStorage( picture.jpgFile.writeJpeg(fitInto(maxStorableImageSizePx)) picture.thumbnailJpgFile.writeJpeg(fitInto(storableThumbnailSizePx)) } - pictures.add(0, picture) picture.jsonFile.writeText(picture.toJson()) } }