simple_parallax 0.0.2 simple_parallax: ^0.0.2 copied to clipboard
This Flutter plugin provides a simple and customizable parallax effect for your applications.
SimpleParallax Plugin for Flutter #
This Flutter plugin provides a simple and customizable parallax effect for your applications. Easily create stunning visual experiences by incorporating parallax scrolling into your widgets.
Features #
- Smooth parallax scrolling for background images.
- Configurable scroll speed for the parallax effect.
- Simple integration with your existing Flutter projects.
- Uses provider for state management ensuring efficient updates.
Usage #
To use this plugin, wrap your scrollable content with the "SimpleParallax" and provide the path to your background image. Adjust the speed parameter to control the intensity of the parallax effect.
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: SimpleParallax(
imagePath: 'assets/images/background.jpg', // Background image
speed: 0.3, // Speed of parallax effect
decal: 1.0, // Start position of background image
// Scrollable content
child: Column(
children: List.generate(
20,
(index) => Container(
height: 100,
margin: const EdgeInsets.symmetric(vertical: 10),
color: Colors.white.withOpacity(0.8),
child: Center(child: Text('Item $index')),
),
),
),
),
),
);
}
}
Tip to avoid background image overflow #
Calculate best parallax speed
/// Use a Statefull widget
class _MyAppState extends State<MyApp> {
double _contentHeight = 1;
/// We use a GlobalKey to get a reference to the content widget.
final _contentKey = GlobalKey();
void _calculateHeight() {
/// This method uses the GlobalKey to get the size of the content after rendering.
/// RenderBox is used to access the dimensions of the widget.
final RenderBox renderBox = _columnKey.currentContext!.findRenderObject() as RenderBox;
setState(() {
_contentHeight = renderBox.size.height;
});
}
@override
void initState() {
super.initState();
/// We add a postFrameCallback in initState to calculate the height of
/// the content after the widget has been rendered.
WidgetsBinding.instance.addPostFrameCallback((_) => _calculateHeight());
}
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: Center(
child: SizedBox(
height: widgetHeight,
width: widgetWidth,
child: SimpleParallax(
imagePath: 'assets/images/background.jpg',
speed: widgetHeight / _contentHeight, // Calculating the ideal speed
decal: 1.0,
child: Column(
key: _contentKey,
children: List.generate(
numberItems,
(index) => Container(
height: itemHeight,
margin: const EdgeInsets.symmetric(vertical: itemMargin),
color: Colors.white.withOpacity(0.8),
child: Center(child: Text('Item $index')),
),
),
),
),
),
),
),
);
}
}