My other APIs
Features
- Fancy animations.
- Customizable colors.
- Works with the back button.
- Scrolling pages by gestures.
- Indicator that follows the scroll.
- Easy and powerful implementation! :)
- Page movement when tapping an icon.
NavigationPosition.bottom |
NavigationPosition.top |
data:image/s3,"s3://crabby-images/2eefd/2eefd1895164055cd47dbffcc20b0613bb25a032" alt="" |
data:image/s3,"s3://crabby-images/89081/89081517148e7543e9120b47dc476c6ac5c2ff87" alt="" |
Code
@override
Widget build(BuildContext context) {
return ScrollNavigation(
bodyStyle: NavigationBodyStyle(
background: Colors.white,
borderRadius: BorderRadius.vertical(bottom: Radius.circular(20)),
),
barStyle: NavigationBarStyle(
background: Colors.white,
elevation: 0.0,
),
pages: [
Container(color: Colors.blue[100]),
Container(color: Colors.green[100]),
Container(color: Colors.purple[100]),
Container(color: Colors.amber[100]),
Container(color: Colors.deepOrange[100])
],
items: const [
ScrollNavigationItem(icon: Icon(Icons.camera)),
ScrollNavigationItem(icon: Icon(Icons.chat)),
ScrollNavigationItem(icon: Icon(Icons.favorite)),
ScrollNavigationItem(icon: Icon(Icons.notifications)),
ScrollNavigationItem(icon: Icon(Icons.home))
],
);
}
NavigationPosition.left |
NavigationPosition.right |
data:image/s3,"s3://crabby-images/b70af/b70af4891c3f73c16be485e77fa56c1b3165c810" alt="" |
data:image/s3,"s3://crabby-images/f5db9/f5db931322c0beca28c15e87a459dcb74e3183fa" alt="" |
Code
@override
Widget build(BuildContext context) {
return ScrollNavigation(
bodyStyle: NavigationBodyStyle(
background: Colors.white,
borderRadius: BorderRadius.horizontal(left: Radius.circular(20)),
scrollDirection: Axis.vertical,
),
barStyle: NavigationBarStyle(
position: NavigationPosition.left,
elevation: 0.0,
background: Colors.white,
),
pages: [
Container(color: Colors.blue[100]),
Container(color: Colors.green[100]),
Container(color: Colors.purple[100]),
Container(color: Colors.amber[100]),
Container(color: Colors.deepOrange[100])
],
items: const [
ScrollNavigationItem(icon: Icon(Icons.camera)),
ScrollNavigationItem(icon: Icon(Icons.chat)),
ScrollNavigationItem(icon: Icon(Icons.favorite)),
ScrollNavigationItem(icon: Icon(Icons.notifications)),
ScrollNavigationItem(icon: Icon(Icons.home))
],
);
}
Go to a Page Code
final navigationKey = GlobalKey<ScrollNavigationState>();
@override
Widget build(BuildContext context) {
return ScrollNavigation(
key: navigationKey,
pages: [...],
items: [...],
barStyle: NavigationBarStyle(position: NavigationPosition.top),
);
}
void goToPage(int index) => navigationKey.currentState.goToPage(index);
Identifier Details
physics = true |
physics = False |
data:image/s3,"s3://crabby-images/75d06/75d06b85f5f212cad1b9ec44dfba70c9412252dd" alt="" |
data:image/s3,"s3://crabby-images/9e7d3/9e7d39d26960eedc1c3c3a296a4da4d0b61d0fc7" alt="" |
position = IdentifierPosition.topAndRight |
showIdentifier = False |
data:image/s3,"s3://crabby-images/850fc/850fc2c87254ad7e865e6321b7a7ae4f8ac8909d" alt="" |
data:image/s3,"s3://crabby-images/8702f/8702f5d5032f8b85aa352276945a0ffa82398635" alt="" |
Code
return ScrollNavigation(
pages: [...],
items: [...],
physics: true,
showIdentifier: true,
identiferStyle: NavigationIdentiferStyle(
position: NavigationPosition.top,
),
);
data:image/s3,"s3://crabby-images/d5f10/d5f10e8e26ce0bfd90a5500be74987d107d3f471" alt=""
Code
return TitleScrollNavigation(
barStyle: TitleNavigationBarStyle(
style: TextStyle(fontWeight: FontWeight.bold),
padding: EdgeInsets.symmetric(horizontal: 40.0),
spaceBetween: 40,
),
titles: [
"Main Page",
"Personal Information",
"Personalization",
"Security",
"Payment Methods",
],
pages: [
Container(color: Colors.blue[50]),
Container(color: Colors.red[50]),
Container(color: Colors.green[50]),
Container(color: Colors.purple[50]),
Container(color: Colors.yellow[50]),
],
);
data:image/s3,"s3://crabby-images/ad6d1/ad6d1fecf74f3d59758164b65c789c52f2ca566d" alt=""
Code
ScrollController controller = ScrollController();
return Screen(
appBar: AppBarTitle(title: "Title Scroll", showBack: true), //WIDGET IN THE EXAMPLE
controllerToHideAppBar: controller,
body: ListView.builder(
itemCount: 15,
padding: EdgeInsets.zero,
controller: controller,
itemBuilder: (_, __) {
return Padding(
padding: EdgeInsets.symmetric(vertical: 5),
child: Container(
height: 50,
color: Colors.blue[50],
),
);
},
),
);