-
Notifications
You must be signed in to change notification settings - Fork 403
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement CoilImageLoader #191
Comments
PR is welcome! |
Before PR, is something like that suitable ? Or did I miss a very important notion? I have never used Fresco, so I could not use it as a reference. import android.content.Context
import android.graphics.Bitmap
import android.graphics.Bitmap.CompressFormat
import android.graphics.drawable.BitmapDrawable
import android.net.Uri
import coil.Coil
import coil.api.load
import coil.request.RequestDisposable
import com.github.piasy.biv.loader.ImageLoader
import com.github.piasy.biv.metadata.ImageInfoExtractor
import timber.log.Timber
import java.io.File
import java.io.FileOutputStream
import java.io.OutputStream
/**
* Created by Piasy{github.com/Piasy} on 09/11/2016.
*/
class CoilImageLoader(var context: Context, var imageLoader: coil.ImageLoader? = null) : ImageLoader {
private val mRequestDisposableMap = hashMapOf<Int, RequestDisposable>()
private val mImageLoader = imageLoader ?: Coil.loader()
override fun loadImage(requestId: Int, uri: Uri, callback: ImageLoader.Callback) {
val file = File(context.filesDir.toString(), "latestImageDownloaded.jpg")
val disposable = mImageLoader.load(context, uri) {
target(
onStart = { callback.onStart() },
onSuccess = { result ->
if (result is BitmapDrawable) {
saveBitmapToFile(file, result.bitmap, CompressFormat.JPEG, 100)
}
callback.onCacheHit(ImageInfoExtractor.getImageType(file), file)
callback.onSuccess(file)
},
onError = {
callback.onFail(Exception("Error on loading image with Coil"))
}
)
}
saveTarget(requestId, disposable)
}
private fun saveBitmapToFile(imageFile: File, bitmap: Bitmap, format: CompressFormat?, quality: Int) {
val os: OutputStream
try {
os = FileOutputStream(imageFile)
bitmap.compress(format, quality, os)
os.flush()
os.close()
} catch (e: Exception) {
Timber.e(e, "Error writing bitmap")
}
}
override fun prefetch(uri: Uri) {
// Do nothing
}
override fun cancel(requestId: Int) {
clearTarget(requestId)
}
private fun clearTarget(requestId: Int) {
mRequestDisposableMap.remove(requestId)?.dispose()
}
override fun cancelAll() {
for (key in mRequestDisposableMap.keys) {
cancel(key)
}
}
private fun saveTarget(requestId: Int, disposable: RequestDisposable) {
mRequestDisposableMap[requestId] = disposable
}
} Declared like this : BigImageViewer.initialize(
CoilImageLoader(applicationContext, ImageLoader(applicationContext) {
// Custom params ...
allowRgb565(false)
})
) We actually don't need to pass okHttpClient in parameters because we can create a custom ImageLoader from Coil like this: ImageLoader(context) {
okHttpClient {
// Custom OkHttpClient
OkHttpClient.Builder()
.cache(CoilUtils.createDefaultCache(context))
.build()
}
} |
Looks cool. 👍 |
Heyah! |
No. I didn't had time to work on it. What's given above is working like that, you can add it in your project, or better take it and do a PR. 😉 |
I wrote up a test project to run a quick test, and it seemed that there was some errors with Coil.loader() and target I'm not at all familiar with Coil at the moment, but once I get around to experimenting with it maybe I'll be able to figure out something. 😄 |
Keep in mind that the above code saves each image into a file twice -- once when Coil downloads the image and once when |
Since Coil |
Hi, any plan for supporting Coil image loading library ?
https://github.com/coil-kt/coil
Thx,
The text was updated successfully, but these errors were encountered: