This requires ImageProvider as an argument for each of the placeholder, thumbnail and image parameters.
Note - image will start to load only after the thumbnail is resolved completely.
Widget example1 = ProgressiveImage(
placeholder: AssetImage('assets/images/placeholder.jpg'), // @required
thumbnail: NetworkImage('https://i.imgur.com/eOQL4jg.jpg'), // @required
image: NetworkImage('https://i.imgur.com/mDQ3Qbi.jpg'), // @required
height: 300, // @required
width: 500, // @required
fit: BoxFit.cover, // default BoxFit.fill
);Creates a widget that uses a placeholder image stored in an asset bundle while loading the thumbnail and target image from the network.
Widget example2 = ProgressiveImage.assetNetwork(
placeholder: 'assets/images/placeholder.gif', // gifs can be used
thumbnail: 'https://i.imgur.com/7XL923M.jpg',
image: 'https://i.imgur.com/xVS07vQ.jpg',
height: 250,
width: 500,
fit: BoxFit.cover,
);Creates a widget that uses a placeholder image stored in memory while loading the thumbnail and target image from the network.
Widget example3 = ProgressiveImage.memoryNetwork(
// see transparent_image package for kTransparentImage usage
placeholder: kTransparentImage,
thumbnail: 'https://i.imgur.com/vz6P3pD.jpg',
image: 'https://i.imgur.com/GL54OhH.jpg',
height: 250,
width: 500,
);