GlideWebpDecoder is a Glide integration library for decoding and displaying webp images on Android platforms. It is based on libwebp project and takes some implementation from Fresco and GlideWebpSupport as references.
- play animated webp images on all Android versions
- show transparent or lossless webp images on Android devices lower than 4.2.1 (BitmapFactory support webp decode on 4.2+ android system so we have no need to handle)
Library is available in jcenter. If you build with Gradle, just add the following dependencies to your build.gradle
file.
Different Glide version is corresponding to different GlideWebpDecoder due to the annotation processor compatibility. The version rule of GlideWebpDecoder is "{major_version}.{glide_version}".
For example, if you use glide 4.11.0, the corresponding version of GlideWebpDecoder should be 1.7.4.11.0
Library will only follow the latest three version of Glide. If you use a lower version glide, please clone the project and modify it yourself.
Since Glide 4.10.0 has migrate to AndroidX, so your project must use AndroidX too with Glide 4.10.0+. webpdeocder with androidx is published is 1.6.4.10.0
Glide 4.7.0 is not available in maven, see issue 3015
Glide 4.6.0 is broken, see issue 2863
def GLIDE_VERSION = "4.11.0"
// webpdecoder
implementation "com.zlc.glide:webpdecoder:1.7.${GLIDE_VERSION}"
// glide 4.6.1~4.10.0 (exclude broken version 4.6.0, 4.7.0)
implementation "com.github.bumptech.glide:glide:${GLIDE_VERSION}"
annotationProcessor "com.github.bumptech.glide:compiler:${GLIDE_VERSION}"
Then you are free to use GlideWebpDecoder just like using other Glide integration library.
Basic usage see Glide API documents
If you want to use BitmapTransformation
or library glide-transformations, please use WebpDrawableTransformation
to wrap your original BitmapTransformation
when loading image with Glide request.
Code Snippet as follow. Run sample project to see other Glide built-in transformation effect.
Transformation<Bitmap> circleCrop = new CircleCrop();
GlideApp.with(mContext)
.load(url)
.optionalTransform(circleCrop)
.optionalTransform(WebpDrawable.class, new WebpDrawableTransformation(circleCrop))
.into(imageView);
The library use native code to decode webp, so you should put the following lines to your proguard.cfg
and keep the jni interface.
-keep public class com.bumptech.glide.integration.webp.WebpImage { *; }
-keep public class com.bumptech.glide.integration.webp.WebpFrame { *; }
-keep public class com.bumptech.glide.integration.webp.WebpBitmapFactory { *; }
The Library is Apache-2.0-licensed, part code is MIT-licensed see Fresco for detail.