Android: Glide Not Showing Large Image From URL


Answer :

I have found a solution that worked for my requirement. The override() method does the trick. Setting higher numbers for the target resolution seems to be the final workaround, but the bigger the numbers, the longer the time it would take to display the image(s), so it would be wise to implement a preloader/progressbar.

Glide.with(getContext())     .asBitMap() //[for new glide versions]     .load(url)     //.asBitmap()[for older glide versions]     //.placeholder(R.drawable.default_placeholder)     .override(1600, 1600) // Can be 2000, 2000     .into(new BitmapImageViewTarget(imageViewPreview) {         @Override         public void onResourceReady(Bitmap  drawable, GlideAnimation anim) {             super.onResourceReady(drawable, anim);             progressBar.setVisibility(View.GONE);         }     }); 

Custom centered preloader/progressbar placeholder indicator on relativeLayout xml:

<ProgressBar     android:id="@+id/progressBar"     android:layout_width="wrap_content"     android:layout_height="wrap_content"     android:layout_centerInParent="true" /> 

This is neat because another issue related about loading image asBitmap() in Glide will not show placeholders for error and preloader/progress indicator:

Glide.with(getActivity())     .load(url).asBitmap()     .placeholder() //<== will simply not work:     .error() // <== is also useless     .into(new SimpleTarget<Bitmap>() { @Override public void onResourceReady(Bitmap resource, GlideAnimation<? super Bitmap> glideAnimation) {         imageView.setImageBitmap(resource);     } }); 

In my research, I have also tried a Picasso solution to handle high quality image:

Picasso.with(getContext())                 .load(url)                 .resize(1500, 0)                 .placeholder(R.drawable.default_placeholder)                 .error(R.drawable.download_error)                 .into(imageViewPreview); 

In the end, I was happy with the Glide version.

I hope this will be helpful to anyone that might be facing the same challenge.


I had issue while loading image from url into TouchImageView using Glide. It would show a black screen. I found a fix which works like this. Pass width and height in Glide override method and after setting bitmap call setZoom of TouchImageView with value 1.

Here is the complete code:

Glide.with('context')                     .asBitmap()                     .load('url')                     .apply(new RequestOptions().override(1600, 1600)) //This is important                      .into(new BitmapImageViewTarget('imageview') {                         @Override                         public void onResourceReady(@NonNull Bitmap resource, @Nullable Transition<? super Bitmap> transition) {                             super.onResourceReady(resource, transition);                             'imageview'.setImageBitmap(resource);                             'imageview'.setZoom(1); //This is important                         }                     }); 

Comments

Popular posts from this blog

Converting A String To Int In Groovy

"Cannot Create Cache Directory /home//.composer/cache/repo/https---packagist.org/, Or Directory Is Not Writable. Proceeding Without Cache"

Android SDK Location Should Not Contain Whitespace, As This Cause Problems With NDK Tools