Load SVGs in Android with Glide
GlideToVectorYou
Load SVGs with Glide
GlideToVectorYou enables you to easily load your remote vector images (only .svg are supported for now) like other image formats.
The library is based on Glide and offers the same functionalities + svg support.
How to use
Add JitPack in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url 'https://jitpack.io' }
}
}
Add the dependency in your app build.gradle:
dependencies {
compile 'com.github.2coffees1team:GlideToVectorYou:v1.0'
}
There are 3 ways to use this library.
Lazy way
You just have to use a method:
GlideToVectorYou.justLoadImage(activity, IMAGE_URI, targetImageView)
The svg will be automatically downloaded and inserted in your target Image View.
Easy eh?
Normal way
GlideToVectorYou
.init()
.with(this)
.withListener(new GlideToVectorYouListener() {
@Override
public void onLoadFailed() {
Toast.makeText(context, "Load failed", Toast.LENGTH_SHORT).show()
}
@Override
public void onResourceReady() {
Toast.makeText(context, "Image ready", Toast.LENGTH_SHORT).show()
}
})
.setPlaceHolder(placeholderLoading, placeholderError)
.load(IMAGE_URL, imageview);
Here you have more methods to customize the behaviour of GlideToVectorYou. You can for example:
- set a custom listener to respond to events with
withListener()
- show place holders while the image is loading or the loading failed with
setPlaceHolder()
.
Advanced way
If you are a Glide pro, you can ask GlideToVectorYou to give you access to the original Glide's RequestBuilder
.
RequestBuilder<PictureDrawable> requestBuilder = GlideToVectorYou
.init()
.with(this)
.getRequestBuilder();
Here you can use the variable requestBuilder like a normal Glide request. The only difference is that it will still continue to work with SVGs :)
Again, for example, you could apply a custom transition or crop the image:
requestBuilder
.load(IMAGE_URI)
.transition(DrawableTransitionOptions.withCrossFade())
.apply(new RequestOptions()
.centerCrop())
.into(imageView);
Licence
This library is shared under Apache License 2.0.