|
|
|
# Flutter slider drawer
|
|
|
|
|
|
|
|
[data:image/s3,"s3://crabby-images/572af/572afd692d1fee2a1798ca1fb79818c7b943ce75" alt="pub package"](https://pub.dev/packages/flutter_slider_drawer) [data:image/s3,"s3://crabby-images/28b98/28b98aee6dc78bdc22d35636085873acb6bcc71f" alt="pub package"](https://pub.dev/packages/flutter_slider_drawer)
|
|
|
|
|
|
|
|
|
|
|
|
A Flutter package with custom implementation of the Slider Drawer Menu
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/586ba/586ba77a2303532b9527eaf9bf103c64ce07678d" alt="Plugin example demo"
|
|
|
|
<img src="slider_2.gif" alt="drawing" width="250" height="481"/>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
To start using this package, add `flutter_slider_drawer` dependency to your `pubspec.yaml`
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
dependencies:
|
|
|
|
flutter_slider_drawer: '<latest_release>'
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Features
|
|
|
|
|
|
|
|
- Slider with custom animation time
|
|
|
|
- Provide Basic Appbar with customization of color, size and title
|
|
|
|
- Dynamic slider open and close offset
|
|
|
|
- Provide drawer icon animation
|
|
|
|
- Provide shadow of Main screen with customization of shadow colors,blurRadius and spreadRadius
|
|
|
|
- Provide RTL(RightToLeft),LTR(LeftToRight) and TTB(TopToBottom) slider open selection
|
|
|
|
|
|
|
|
# Code
|
|
|
|
|
|
|
|
```
|
|
|
|
Scaffold(
|
|
|
|
body: SliderDrawer(
|
|
|
|
key: _key,
|
|
|
|
appBar: SliderAppBar(
|
|
|
|
appBarColor: Colors.white,
|
|
|
|
title: Text(title,
|
|
|
|
style: const TextStyle(
|
|
|
|
fontSize: 22, fontWeight: FontWeight.w700))),
|
|
|
|
slider: Container(color: Colors.red),
|
|
|
|
child: Container(color: Colors.amber),
|
|
|
|
))
|
|
|
|
```
|
|
|
|
|
|
|
|
</br>
|
|
|
|
</br>
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/52db8/52db84ed3eb694175b9fcc170899d09dc0bc762c" alt="slider_document"
|
|
|
|
</br>
|
|
|
|
</br>
|
|
|
|
</br>
|
|
|
|
</br>
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/18564/18564f0cd9cc730a981cdf93427e76019334727e" alt="slider_document"
|
|
|
|
|
|
|
|
|
|
|
|
# Slider open
|
|
|
|
|
|
|
|
| SliderOpen.LEFT_TO_RIGHT | SliderOpen.RIGHT_TO_LEFT | SliderOpen.TOP_TO_BOTTOM |
|
|
|
|
|---|---|---|
|
|
|
|
| data:image/s3,"s3://crabby-images/b03bc/b03bc6b881cf108a99da1c9c4717d1cf1565edcc" alt="slider_left" | data:image/s3,"s3://crabby-images/7d179/7d1794e067a6f3884bdb2c90dd70ac3bfc99dae5" alt="slider_right" | data:image/s3,"s3://crabby-images/9aae3/9aae3c8e5c54ad2619d2a020e599f69c2af54eaf" alt="slider_top" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### Controlling the drawer
|
|
|
|
|
|
|
|
```
|
|
|
|
GlobalKey<SliderDrawerState> _key =
|
|
|
|
new GlobalKey<SliderDrawerState>();
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
|
|
|
body: SliderDrawer(
|
|
|
|
key: _key,
|
|
|
|
appBar: SliderAppBar(
|
|
|
|
appBarColor: Colors.white,
|
|
|
|
title: Text(title,
|
|
|
|
style: const TextStyle(
|
|
|
|
fontSize: 22, fontWeight: FontWeight.w700))),
|
|
|
|
slider: Container(color: Colors.red),
|
|
|
|
child: Container(color: Colors.amber),
|
|
|
|
)),
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
* Using the below methods to control drawer .
|
|
|
|
```
|
|
|
|
_key.currentState.closeDrawer();
|
|
|
|
_key.currentState.openDrawer();
|
|
|
|
_key.currentState.toggle();
|
|
|
|
_key.currentState.isDrawerOpen();
|
|
|
|
|
|
|
|
```
|
|
|
|
* Use below variable if you want to control animation.
|
|
|
|
|
|
|
|
|
|
|
|
``` _key.currentState.animationController```
|
|
|
|
|
|
|
|
License
|
|
|
|
----
|
|
|
|
|
|
|
|
BSD 2-Clause License
|