Skip to content

folksable/mesh_gradient

 
 

Repository files navigation

Mesh Gradient

A widget to create beautiful fluid-like mesh gradients in Flutter.

Pub Version

AnimatedMeshGradient Demo

Features

  • Fluid animation: The widget animates smoothly between the four specified colors, creating a visually appealing fluid effect.
  • Customizable options: Control the animation speed, frequency, and amplitude to achieve the desired visual effect.
  • Frozen mesh gradient: Set a seed which gives back a static snapshot of the gradient animation.
  • Highly performant: Built with Flutter CustomPainter and FragmentShader, the widget ensures optimal performance and smooth animation even on lower-end devices.
  • Easy integration: Simply add the widget to your Flutter project and customize the colors and options to suit your application's design.

Getting Started

Follow these steps to integrate Mesh Gradient into your Flutter project:

Usage

Import the package in your Dart file:

import 'package:mesh_gradient/mesh_gradient.dart';

To use the widget, add it to your widget tree like this:

AnimatedMeshGradient(
  colors: [
    Colors.red,
    Colors.blue,
    Colors.green,
    Colors.yellow,
  ],
  options: AnimatedMeshGradientOptions(),
)

If you need to control the animation manually, you can use AnimatedMeshGradientController like this:

// Initialize the controller
late final AnimatedMeshGradientController _controller = AnimatedMeshGradientController();

...

// Reference in the widget
AnimatedMeshGradient(
  colors: [
    Colors.red,
    Colors.blue,
    Colors.green,
    Colors.yellow,
  ],
  options: AnimatedMeshGradientOptions(),
  controller: _controller,
)

...

// Use it to your needs
void toggleAnimation() {
  _controller.isAnimating.value ? _controller.stop() : _controller.start();
}

...

// If you need to react to controller changes in your widget,
// just wrap it with [ValueListenableBuilder]
ValueListenableBuilder(
  valueListenable: _controller.isAnimating,
  builder: (context, value, child) {
    return Text(value ? 'Dancing' : 'Chilling');
  }
)

Options

The AnimatedMeshGradient allows you to customize its appearance and behavior with the following options:

  • colors: A list of four Color objects that define the gradient colors used in the animation.
  • speed: The animation speed, controlling how fast the fluid effect moves. A higher value means faster animation.
  • frequency: The frequency of the fluid wave. Higher values create more ripples.
  • amplitude: The amplitude of the fluid wave. Higher values create more pronounced deformations.
  • seed: A seed value that gives back a static snapshot of the animation. This stops the animation.

Feel free to experiment with different values to achieve the perfect look for your application!

Credits

Mesh Gradient makes use of the following packages:

Issues and Contributions

If you encounter any issues or have suggestions for improvements, please feel free to open an issue. Contributions are also welcome!

License

This package is licensed under the MIT License.

About

a fork of mesh_gradient on pub.dev

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dart 62.0%
  • GLSL 38.0%