Shimmer Animation

  Animation

Supports Null Safety

This shimmer animation widget can help you bring simple yet beautiful skeleton loaders to your project with ease.

Shimmer is very widely used as the default animation for skeleton loaders or placeholder widgets throughout the development community. Therefore, having an easy-to-use, yet customizable widget ready to use for Android, iOS, and Web, gives developers an advantage to focus on their actual functionality, let Shimmer make the loading experience smoother.

Examples

An example can be found in the example directory of this repository.

A list of detailed examples can be found in this Examples Repository

How to use

Add shimmer_animation to pubspec.yaml of your project:

dependencies:
  shimmer_animation: ^2.1.0

Import it in your Dart code:

import 'package:shimmer_animation/shimmer_animation.dart';

Wrap any widget with Shimmer() widget to apply animaton:

  Shimmer(
    child: Container(
      color: Colors.deepPurple,
    ),
  ),

A number of parameters can be passed to customise the look and feel of this animation:

  Shimmer(
    duration: Duration(seconds: 3), //Default value
    interval: Duration(seconds: 5), //Default value: Duration(seconds: 0)
    color: Colors.white, //Default value
    colorOpacity: 0, //Default value
    enabled: true, //Default value
    direction: ShimmerDirection.fromLTRB(),  //Default Value
    child: Container(
      color: Colors.deepPurple,
    ),
  ),

Parameters:

  • @required child : accepts a child Widget over which the animation is to be displayed
  • color : accepts a parameter of type Color and sets the color of the animation overlay. Default value is Colors.white
  • color: accepts a parameter of type double and sets the Opacity of the color of the animation overlay. The default value is 0.3
  • enabled: accepts a bool which toggles the animation on/off. The default value is true
  • duration: accepts a Duration that would be the time period of animation. Default value is Duration(seconds: 3)
  • interval: accepts a Duration that would be the interval between the repeating animation. The default value is Duration(seconds: 0) i.e. no interval
  • direction: accepts a ShimmerDirection and aligns the animation accordingly. The default value is ShimmerDirection.fromLBRT()

A detailed API Reference can be found here.

Download and/or contribute to this package source code on GitHub