I want to use Picasso to load three consecutive images one on top of each other in a listview. Using the methods Picasso provides makes this easy. However because these images are loading in at different times it causes a flickering effect as the images come in. For example sometimes image 2 appears before image 1, and when image 1 loads it causes an unnatural stutter. It would be better if I could set the listview's visibility to invisible until all the images are available to be shown. However, there is no callback method I could find for Picasso that would signal when an image has been loaded.
Does anyone know of a solution for this kind of a situation using Picasso?
Thanks
You could use the
Target
object. Oncetarget1
receives the callback, you can download the 2nd asset, then get the callback intarget2
, then trigger the 3rd download.This is loading a image url into an imageview with simple picasso callbacks
And this is picasso image loading with more callbacks
You can implement a callback with Picasso like shown below:
The implementation of my ImageHandler class is shown below:
Here is a simple example how to impement Picasso picture loading callback:
The
.into
method provides a second argument which is a callback to success and failure. You can use this to keep track of when all three have been called and act on their visibility all at once.Javadoc: https://square.github.io/picasso/2.x/picasso/com/squareup/picasso/RequestCreator.html#into-android.widget.ImageView-com.squareup.picasso.Callback-