AsyncDownSamplingImage
AsyncDownSamplingImage
is a SwiftUI component that has similar interface to original AsyncImage and can perform downsampling so that we can reduce the memory buffer to store image data fetched from a server.
Impact of Downsampling
with downsampling, we can reduce the huge amount of memory use like the below.
default AsyncImage |
AsyncDownSamplingImage (×2~3 efficient) |
data:image/s3,"s3://crabby-images/88753/887538bda3688e856ae6b44cf91248d5deb5d1df" alt="Screenshot 2023-02-03 at 21 58 31" |
data:image/s3,"s3://crabby-images/158c5/158c5dc930da04d5478cfe97cd89c08a4c6ad914" alt="Screenshot 2023-02-03 at 21 58 48" |
Moreover, the more the number of images increases, the more we can get the benefit.
Below is a comparision when I scrolled and show 100/1000 high resolution images (1000×1000px).
With AsyncDownSamplingImage, we changed Image size 1000x1000
into 160x160
which is same size as rendered Image
.
100 Default AsyncImages |
100 AsyncDownSamplingImages (×10~ efficient) |
data:image/s3,"s3://crabby-images/355eb/355ebf4b1513da6d752286ba2f47c367058dfc18" alt="Screenshot 2023-02-04 at 2 11 31" |
data:image/s3,"s3://crabby-images/fd98d/fd98d1c8b4833e070127256be9184eb1639de3f7" alt="Screenshot 2023-02-04 at 2 12 06" |
1000 Default AsyncImages |
1000 AsyncDownSamplingImages (×30~ efficient) |
data:image/s3,"s3://crabby-images/fade1/fade1179092a744835162bd1e8366db953f1d36a" alt="Screenshot 2023-02-06 at 1 08 46" |
data:image/s3,"s3://crabby-images/e4c94/e4c948463026ee8859bce771f401bd0748bdc164" alt="Screenshot 2023-02-06 at 1 07 29" |
How to use AsyncDownSamplingImage
AsyncDownSamplingImage
aims to be used in a similar way to AsyncImage
even if the implementation is different.
public init(
url: Binding<URL?>,
downsampleSize: Binding<CGSize>,
content: @escaping (Image) -> Content,
placeholder: @escaping () -> Placeholder,
fail: @escaping (Error) -> Fail
)
public init(
url: URL?,
downsampleSize: Binding<CGSize>,
content: @escaping (Image) -> Content,
fail: @escaping (Error) -> Fail
)
public init(
url: URL?,
downsampleSize: CGSize,
content: @escaping (Image) -> Content,
fail: @escaping (Error) -> Fail
)
You can use AsyncDownSamplingImage
in the following way.
@State private var url = URL(string: "https://via.placeholder.com/1000")
@State private var size: CGSize = .init(width: 160, height: 160)
...
AsyncDownSamplingImage(
url: url,
downsampleSize: size
) { image in
image.resizable()
.frame(width: size.width, height: size.height)
} fail: { error in
Text("Error: \(error.localizedDescription)")
}
DocC
Documentation generated by DocC is available (still working in progress).
Contributing
Pull requests, bug reports and feature requests are welcome 🚀
License
MIT LICENSE
AsyncDownSamplingImage
AsyncDownSamplingImage
is a SwiftUI component that has similar interface to original AsyncImage and can perform downsampling so that we can reduce the memory buffer to store image data fetched from a server.Impact of Downsampling
with downsampling, we can reduce the huge amount of memory use like the below.
Moreover, the more the number of images increases, the more we can get the benefit.
Below is a comparision when I scrolled and show 100/1000 high resolution images (1000×1000px). With AsyncDownSamplingImage, we changed Image size
1000x1000
into160x160
which is same size as renderedImage
.How to use AsyncDownSamplingImage
AsyncDownSamplingImage
aims to be used in a similar way toAsyncImage
even if the implementation is different.You can use
AsyncDownSamplingImage
in the following way.DocC
Documentation generated by DocC is available (still working in progress).
Contributing
Pull requests, bug reports and feature requests are welcome 🚀
License
MIT LICENSE