inkblob_navigation_bar

Creator: coderz1093

Last updated:

0 purchases

inkblob_navigation_bar Image
inkblob_navigation_bar Images
Add to Cart

Description:

inkblob navigation bar

Inkblob_navigation_bar #
A custom navigation bar with smooth & dynamic ink blob transition effect.
Overview #
This packages was inspired by this post from Dribbble
Implemented:

Gallery #
Dynamic Movement #

Customizable Curve #

Custom Colors #

Optional Titles #

Works with any widgets #

How to install #
Simply add the package to your dependencies! No other steps required :)
Documentation #
To use the InkblobNavigationBar you can simply use it in the bottomNavigationBar field of your material scaffold:
Scaffold(
...
bottomNavigationBar: InkblobNavigationBar(
...
)
)
copied to clipboard
You can customize these attributes in the navigation bar. #



Attributes
Type
Description
Default




showElevation
bool
Enable subtle shadow effect
true


items
List<InkblobBarItem>
Item data for NavigationBar
required


onItemSelected
Function(int)
Callback function when item tapped
null


selectedIndex
int
Selected item index of navigation bar.
required


previousIndex
int
Previously selected item index of navigation bar.
selectedIndex


iconSize
double
Size of icons.
24.0


backgroundColor
Color
Background color of [CustomNavigationBar]
Theme.bottomAppBarColor


containerHeight
double
Height of the NavigationBar
60


itemWidth
double
Total width of each item
2*containerHeight


curve
Curve
Animation curve of scale effect
Curves.easInOutExpo


animationDuration
Duration
Duration of the total animation
Duration(milliseconds: 270)



Attention: Both the selectedIndex and previousIndex are required for the animation to perform, an example of how to implement this is shown in the provided example app.
To customize the items in the navigation bar, just supply a list of InkblobBarItem like this.
InkblobNavigationBar(
...
items: [
// Simple Icon with a Title & Color
InkblobBarItem(
title: const Text('User'),
filledIcon: const Icon(SpiriIcons.fi_sr_user),
emptyIcon: const Icon(SpiriIcons.fi_rr_user),
color: Colors.blue,
),
// Custom Containers
InkblobBarItem(
filledIcon: Container(
decoration: BoxDecoration(
color: Colors.black,
borderRadius: BorderRadius.circular(12),
),
),
emptyIcon: Container(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(12),
border: Border.all(color: Colors.black, width: 2),
),
),
),
// Even Text Widgets
InkblobBarItem(
filledIcon: const Text('❤️', style: TextStyle(fontSize: 20)),
emptyIcon: const Text('🖤', style: TextStyle(fontSize: 20)),
color: Colors.red,
),
],
)
copied to clipboard
Example #
Check the example app for a full implementation example.
Contribute #
Issues and pull requests are always welcome!
If you found this project helpful, consider buying me a cup of ☕

PayPal

License

For personal and professional use. You cannot resell or redistribute these repositories in their original state.

Files In This Product:

Customer Reviews

There are no reviews.