Load images from disk cache with Picasso if offline
Asked Answered
B

5

25

I have some images that I download from different web sites when the app starts, by doing this:

Picasso.with(context).load(image_url).fetch();

Now, suppose the user closes the app and turns offline. When the app starts again, Picasso display the images in this way:

Picasso.with(ctx).load(image_url).placeholder(R.drawable.ph).into(imageView);

The problem is that some images are loaded from the disk cache (yellow triangle in debug mode), and for the others Picasso shows the placeholder.

Why? I'm expecting that every image is loaded from the disk cache.

Bimanous answered 30/4, 2014 at 14:58 Comment(1)
Perhaps the fetch() has not completed yet and the result is not stored.Chop
D
40

You can use this code by this strategy Picasso will look for images in cache and if it failed only then image will be downloaded over network.

 Picasso.with(context)
                    .load(Uri.parse(getItem(position).getStoryBigThumbUrl()))
                    .networkPolicy(NetworkPolicy.OFFLINE)
                    .into(holder.storyBigThumb, new Callback() {
                        @Override
                        public void onSuccess() {

                        }

                        @Override
                        public void onError() {
                            // Try again online if cache failed
                            Picasso.with(context)
                                    .load(Uri.parse(getItem(position)
                                            .getStoryBigThumbUrl()))
                            .placeholder(R.drawable.user_placeholder)
                            .error(R.drawable.user_placeholder_error)
                                    .into(holder.storyBigThumb);
                        }
                    });
Despoliation answered 2/12, 2015 at 19:30 Comment(2)
Perfect solution for someone who wants an image caching library! :)Threescore
No need to write this much :) You can specify multiple network policies. For example .networkPolicy(NetworkPolicy.OFFLINE, NetworkPolicy.NO_CACHE) should have a similar behaviour to your codeZestful
C
10

Do this:

Picasso.with(this)
            .load(url)
            .networkPolicy(NetworkPolicy.OFFLINE)
            .into(imageView);

Also check my previous answer, maybe will help you: Invalidate cache in Picasso

Chigetai answered 23/4, 2015 at 2:50 Comment(1)
As stated on the API specification, the OFFLINE policy will force the load from disk, skipping network square.github.io/picasso/2.x/picasso/com/squareup/picasso/…. So, if the image changes on server and I am online, will I never notice the change?Advantage
E
7

This logic worked for me:

if network is available:
    Picasso.with(context).load(image).into(imageView);
else:
    Picasso.with(context).load(image).networkPolicy(NetworkPolicy.OFFLINE).into(imageView);
Evangelistic answered 1/7, 2016 at 22:45 Comment(1)
At least for retrofit:2.2.0, the networkPolicy goes after the load method.Perreira
P
4

Is OkHttp and Okio present on the class path? (or in your dependencies) Because by default Picasso lets the HttpClient handle the caching (it does not do this by default)

You have 2 options

  • include the mentioned dependencies (recommended)
  • specify the cache manually
Palmetto answered 16/9, 2014 at 11:39 Comment(1)
it tooks me 3 bloody days to realize that im not inculding those 2 dependencies with picasso , that was really stupid X( X( thank you for pointing that out :DBrittain
L
1

To avoid creating of separate instance of RequestCreator like here , do this:

 RequestCreator request = mPicasso.load(TextUtils.isEmpty(imageUrl) ? null : imageUrl)
                    .placeholder(R.drawable.ic_default)
                    .error(R.drawable.ic_default)
                    .transform(transformations)
                    .noFade()
                    .centerCrop();
            request
                    .networkPolicy(NetworkPolicy.OFFLINE)
                    .into(mImageView, new Callback.EmptyCallback(){
                        @Override
                        public void onError() {
                            super.onError();
                            request.into(mImageView);
                        }
                    });
Lepidote answered 19/7, 2018 at 8:12 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.