A material navigation bar library which has pretty animations and different ways of arrangement.
compile 'com.moos:Material-BottomBarLayout:1.0.5'
<com.moos.library.BottomBarLayout
android:id="@+id/bottom_bar"
android:layout_width="match_parent"
android:layout_height="56dp"
app:tabs_arrange_way="horizontal"
android:elevation="2dp"
android:layout_alignParentBottom="true">
</com.moos.library.BottomBarLayout>
private BottomTabView tab_home, tab_look, tab_mine;
......
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
BottomBarLayout bottomBarLayout = findViewById(R.id.bottom_bar);
tab_home = new BottomTabView(this);
tab_home.setTabIcon(R.drawable.home);
tab_home.setTabTitle("Home");
tab_look = new BottomTabView(this);
tab_look.setTabIcon(R.drawable.activity);
tab_look.setTabTitle("Discover");
tab_mine = new BottomTabView(this);
tab_mine.setTabIcon(R.drawable.user);
tab_mine.setTabTitle("Mine");
tab_mine.setUnreadCount(100);
bottomBarLayout
.addTab(tab_home)
.addTab(tab_look)
.addTab(tab_mine)
.create(new BottomBarLayout.OnTabSelectedListener() {
@Override
public void onTabSelected(BottomTabView tab) {
//you can switch the fragment here
Log.e(TAG, "onTabSelected: ====="+tab.getTabPosition() );
}
@Override
public void onTabUnselected(BottomTabView tab) {
}
@Override
public void onTabReselected(BottomTabView tab) {
}
});
}
ViewPager viewPager = findViewById(R.id.viewPager);
viewPager.setAdapter(new CardViewPagerAdapter(data));
bottomBarLayout.bindViewPager(viewPager);
As we all known, the common libraries of tab
we used can only change the color of different states of tabs. However, sometimes designers want we use different icon resource , like and . I provide setTabIcon
and setSelectedTabIcon
to set different states of icon resource for tabs.
-
BottomTabView
Description:the tab item of bottom bar, like
TabItem
.The methods document:
Method Usage getTabPosition get the position of current tab setTabIcon set the icon res for tab setTabTitle set the title for tab setTabIconSize set the icon size for tab setTabTitleSize set title text size for tab setTabPadding set padding for each tab setSelectedColor set selected color for tab setUnselectedColor set unselected color for tab setTabIconOnly weather show the tab title setTabTitleOnly weather show the tab icon setBubbleBackground set bg for unread bubble view setBubbleSize set size for bubble, only update the 'vertical size' setUnreadTextSize set size for unread text setUnreadTextColor set color for unread text setUnreadTextPadding set padding of unread text, only for padding left and right setUnreadTextMarginTop set margin top to unreadText setUnreadTextMarginRight set margin right to unreadText getTabIconView get the tab icon's imageView getTabTextView get the tab title view getTabContainer get the container of tab(LinearLayout) setSelectedTabIcon set the selected state icon for tab -
BottomBarLayout
Description:the tabs' container, like
TabLayout
.The methods document:
Method Usage addTab(BottomTabView tab) add the tab for container getCurrentTabPosition get current selected tab's position getTabCount get the count of tabs in container bindViewPager(ViewPager viewPager) bind the viewPager and scroll with it create set call back of tab's selected operation setArrangeType the way of tabs arranges
-
Add the
vertical
style to show the tabs and you can customize your own icon res for selected state of tabs. -
Change the
minSdkVersion
down to 16, avoid of the multiple errors. -
Solve the problem that
setUnselectColor
method not works in initialization. -
- You can disable animations of tabs.
- When we customize our
selectedIcon
, we should disable the icon color setting.
-
Fix the problem that unselected icons still have color filter effect.
- support
horizontal
andvertical
style. - more animations for tabs.
- bind with viewpager or other slide views.
- change bottomBarLayout background when selected.
- support different states of tab icons
- Not limit default icon size any more, change it's size to
wrap_content
.
Welcome to improve it with me and give me some issues.
E-mail:moosphon@gmail.com
Copyright 2018 moosphon
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.