evict method

  1. @override
Future<bool> evict({
  1. ImageCache? cache,
  2. ImageConfiguration configuration = ImageConfiguration.empty,
  3. bool memory = true,
  4. bool disk = false,
})
override

Evicts an entry from the image cache.

Returns a Future which indicates whether the value was successfully removed.

The ImageProvider used does not need to be the same instance that was passed to an Image widget, but it does need to create a key which is equal to one.

The cache is optional and defaults to the global image cache.

The configuration is optional and defaults to ImageConfiguration.empty.

{@tool snippet}

The following sample code shows how an image loaded using the Image widget can be evicted using a NetworkImage with a matching URL.

class MyWidget extends StatelessWidget {
  const MyWidget({
    super.key,
    this.url = ' ... ',
  });

  final String url;

  @override
  Widget build(BuildContext context) {
    return Image.network(url);
  }

  void evictImage() {
    final NetworkImage provider = NetworkImage(url);
    provider.evict().then<void>((bool success) {
      if (success) {
        debugPrint('removed image!');
      }
    });
  }
}

{@end-tool}

Implementation

@override
Future<bool> evict({
  ImageCache? cache,
  ImageConfiguration configuration = ImageConfiguration.empty,
  bool memory = true,
  bool disk = false,
}) async {
  if (memory) {
    cache ??= imageCache;
    final key = await obtainKey(configuration);
    return cache!.evict(key);
  }
  if (disk) {
    return removeFromCache(url);
  }
  return false;
}