mesh_gradient 1.1.6 copy "mesh_gradient: ^1.1.6" to clipboard
mesh_gradient: ^1.1.6 copied to clipboard

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

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.

176
likes
0
points
6.71k
downloads

Publisher

verified publisherben.fornefeld.dev

Weekly Downloads

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

Repository (GitHub)
View/report issues

License

unknown (license)

Dependencies

flutter, flutter_shaders

More

Packages that depend on mesh_gradient