scroll_to_animate_tab
A Flutter widget that is customizable and syncs the ScrollView with the tabs. Create distinct tabs that are coordinated with the internal ScrollView. The tabs come after the index of the scroll view.
Demo
Installation
Add dependency for package on your pubspec.yaml:
dependencies:
scroll_to_animate_tab: latest
or
flutter pub add scroll_to_animate_tab
API
ScrollToAnimateTab
Parameter | Definition |
---|---|
List<ScrollableList> tabs |
List of tabs to be rendered |
double tabHeight |
Height of the tab at the top of the view |
Duration? tabAnimationDuration |
Optional Duration of tab change animation |
Duration? bodyAnimationDuration |
Optional Duration of tab change animation |
Curve? tabAnimationCurve |
Optional Animation curve used when animating tab change |
Curve? bodyAnimationCurve |
Optional Animation curve used when changing index of inner ScrollViews |
Color? backgroundColor |
Optional This property will help you to change the background color of tab bar |
TabDecoration? activeTabDecoration |
Optional Change active tab decoration |
TabDecoration? inActiveTabDecoration |
Optional Change inactive tab decoration |
TabDecoration
Parameter | Definition |
---|---|
TextStyle textStyle | TextStyle for tab label |
Decoration? decoration | decoration for tabs |
ScrollableList
Parameter | Definition |
---|---|
String label | A String for tab label and as headline of ScrollableList.body |
Widget? bodyLabelDecoration | A widget label for decorate body widget. by default its a Text widget as context ScrollableList.label with color: Colors.black ,fontWeight: FontWeight.bold ,fontSize: 21 |
Widget body | A single widget in the scrollable tab list. You can use Column or any single scrollable widget. If you want to use ScrollView (ListView) then we suggest make sure that body is created with ScrollView.shrinkWrap = true and ScrollView.physics = NeverScrollableScrollPhysics. |
inside this TabDecoration, it gives us textStyle
property which is required that helps us to
change tab label style and other is optional named decoration
property which helps us to decorate
our tab.
How to use
Basic Example ->
ScrollToAnimateTab(
activeTabDecoration: TabDecoration(
textStyle: const TextStyle(
color: Colors.red, fontWeight: FontWeight.bold, fontSize: 18),
decoration: BoxDecoration(
border: Border.all(color: Colors.black),
borderRadius: const BorderRadius.all(Radius.circular(5))
)
),
inActiveTabDecoration: TabDecoration(
textStyle: const TextStyle(color: Colors.black),
decoration: BoxDecoration(
border: Border.all(color: Colors.black12),
borderRadius: const BorderRadius.all(Radius.circular(5))
)
),
tabs: [
ScrollableList(
label: "Hello",
body: ListView.builder(
shrinkWrap: true,
physics: const NeverScrollableScrollPhysics(),
itemCount: 10,
itemBuilder: (_, index) => ListTile(
title: Text('List element ${index + 1}'),
),
)
),
ScrollableList(
label: "hello 2",
body: Column(
children: List.generate(
10,
(index) => ListTile(
title: Text('List element ${index + 1}'),
)),
)
),
]
)
Libraries
- scroll_to_animate_tab
- A Flutter widget that is customizable and syncs the ScrollView with the tabs.