BottomBarLayout——方便快捷地实现底部导航栏
转载请注明出处:http://blog.csdn.net/chay_chan/article/details/73715607
轻量级的底部导航栏
目前市场上的App,几乎都有底部页签导航栏,所以我们在开发的时候经常需要用到这个,虽然github上有不少已经封装好的底部导航栏的工具,例如bottombar,alphaIndicator(仿微信滑动渐变底部控件)等,但是这些控件由于功能太多,而且也没有给予详细的介绍文档,所以用起来不是特别容易,有时候我们仅仅只是想要一个简简单单的底部导航,但是又不想去自己在布局中搞一个个LinearLayout或者RadioGroup,然后切换页签的时候更换图标,让ViewPager跳转到对应的页面等一系列繁琐的操作,这时候,你可以使用BottomBarLayout,简简单单就可以实现以下效果:
显示未读数、提示小红点、提示消息
BottomBarLayout的使用
BottomBarItem属性介绍
<!--默认状态下的图标--><attr name="iconNormal" format="reference"/><!--选中状态下的图标--><attr name="iconSelected" format="reference"/><!--底部文字--><attr name="itemText" format="string"/><!--文字大小--><attr name="itemTextSize" format="dimension"/><!--默认状态下的文字颜色--><attr name="textColorNormal" format="color"/><!--选中状态下的文字颜色--><attr name="textColorSelected" format="color"/><!--文字和图标的顶部距离--><attr name="itemMarginTop" format="dimension"/><!--是否开启触摸背景效果--><attr name="openTouchBg" format="boolean"/><!--设置触摸背景--><attr name="touchDrawable" format="reference"/><!--设置图标的宽度--><attr name="iconWidth" format="dimension"/><!--设置图标的高度--><attr name="iconHeight" format="dimension"/><!--设置BottomBarItem的padding--><attr name="itemPadding" format="dimension"/><!--设置未读数字体大小--><attr name="unreadTextSize" format="dimension"/><!--设置提示消息字体大小--><attr name="msgTextSize" format="dimension"/>
布局文件中配置
在xml文件中,配置BottomBarLayout,包裹子条目BottomBarItem
<?xml version="1.0" encoding="utf-8"?>
<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"
><android.support.v4.view.ViewPagerandroid:id="@+id/vp_content"android:layout_width="match_parent"android:layout_height="0dp"android:layout_weight="1"></android.support.v4.view.ViewPager><com.chaychan.library.BottomBarLayoutandroid:id="@+id/bbl"android:layout_width="match_parent"android:layout_height="45dp"android:orientation="horizontal"android:gravity="center"android:layout_gravity="center"android:background="@color/tab_gb"><com.chaychan.library.BottomBarItemandroid:layout_width="0dp"android:layout_weight="1"android:layout_height="match_parent"app:iconNormal="@mipmap/tab_home_normal"app:iconSelected="@mipmap/tab_home_selected"app:itemText="首页"app:textColorNormal="@color/tab_normal_color"app:textColorSelected="@color/tab_selected_color"app:itemTextSize="8sp"app:itemMarginTop="-5dp"/><com.chaychan.library.BottomBarItemandroid:layout_width="0dp"android:layout_weight="1"android:layout_height="match_parent"app:iconNormal="@mipmap/tab_video_normal"app:iconSelected="@mipmap/tab_video_selected"app:itemText="视频"app:textColorNormal="@color/tab_normal_color"app:textColorSelected="@color/tab_selected_color"app:itemTextSize="8sp"app:itemMarginTop="-5dp"/><com.chaychan.library.BottomBarItemandroid:layout_width="0dp"android:layout_weight="1"android:layout_height="match_parent"app:iconNormal="@mipmap/tab_micro_normal"app:iconSelected="@mipmap/tab_micro_selected"app:itemText="微头条"app:textColorNormal="@color/tab_normal_color"app:textColorSelected="@color/tab_selected_color"app:itemTextSize="8sp"app:itemMarginTop="-5dp"/><com.chaychan.library.BottomBarItemandroid:layout_width="0dp"android:layout_weight="1"android:layout_height="match_parent"app:iconNormal="@mipmap/tab_me_normal"app:iconSelected="@mipmap/tab_me_selected"app:itemText="我的"app:textColorNormal="@color/tab_normal_color"app:textColorSelected="@color/tab_selected_color"app:itemTextSize="8sp"app:itemMarginTop="-5dp"/></com.chaychan.library.BottomBarLayout></LinearLayout>
java文件中设置
找过对应的ViewPager和BottomBarLayout,为ViewPager设置Adapter,然后为BottomBarLayout设置ViewPager
mVpContent.setAdapter(new MyAdapter(getSupportFragmentManager()));mBottomBarLayout.setViewPager(mVpContent);
这样就实现底部导航栏功能了
开启滑动效果
页签之间的切换默认关闭了滑动效果,如果需要开启可以通过调用BottomBarLayout的setSmoothScroll()方法:
mBottomBarLayout.setSmoothScroll(true);
开启后效果如下:
设置条目选中的监听
mBottomBarLayout.setOnItemSelectedListener(new BottomBarLayout.OnItemSelectedListener() {@Overridepublic void onItemSelected(final BottomBarItem bottomBarItem, int position) {//do something}});
显示未读数、提示小红点、提示消息
mBottomBarLayout.setUnread(0,20);//设置第一个页签的未读数为20
mBottomBarLayout.setUnread(1,101);//设置第二个页签的未读书
mBottomBarLayout.showNotify(2);//设置第三个页签显示提示的小红点
mBottomBarLayout.setMsg(3,"NEW");//设置第四个页签显示NEW提示文字
当设置的未读数小于或等于0时,消失未读数的小红点将会消失;
当未读数为1-99时,则显示对应的数字;
当未读数大于99时,显示99+;
隐藏提示小红点、提示消息
mBottomBarLayout.hideNotify(2);//隐藏第三个页签显示提示的小红点
mBottomBarLayout.hideMsg(3);//隐藏第四个页签显示的提示文字
BottomBarItem的介绍
BottomBarItem继承于LinearLayout,其子View有显示图标的ImageView和展示文字的TextView,分别可以通过getImageView()和getTextView()方法获取到对应的子控件。github上不少底部导航栏的控件都没能获取到对应的子控件,所以在需要对子控件进行操作的时候极不方便,有一些的思路并不是用ImageView和TextView,而是用绘制的,所以也不能获取到对应的显示图标的控件或展示文字的控件,造成无法获取到该控件,无法进行一些业务上的操作,比如类似今日头条的底部的首页,点击首页的页签,会更换成加载中的图标,执行旋转动画,BottomBarLayout可以轻松地做到这个需求。
演示效果如下:
只需为BottomBarLayout设置页签选中的监听,在回调中进行以下处理:
mBottomBarLayout.setOnItemSelectedListener(new BottomBarLayout.OnItemSelectedListener() {@Overridepublic void onItemSelected(final BottomBarItem bottomBarItem, int position) {if (position == 0){//如果是第一个,即首页if (mBottomBarLayout.getCurrentItem() == position){//如果是在原来位置上点击,更换首页图标并播放旋转动画bottomBarItem.setIconSelectedResourceId(R.mipmap.tab_loading);//更换成加载图标bottomBarItem.setStatus(true);//播放旋转动画if (mRotateAnimation == null) {mRotateAnimation = new RotateAnimation(0, 360,Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF,0.5f);mRotateAnimation.setDuration(800);mRotateAnimation.setRepeatCount(-1);}ImageView bottomImageView = bottomBarItem.getImageView();bottomImageView.setAnimation(mRotateAnimation);bottomImageView.startAnimation(mRotateAnimation);//播放旋转动画//模拟数据刷新完毕mHandler.postDelayed(new Runnable() {@Overridepublic void run() {bottomBarItem.setIconSelectedResourceId(R.mipmap.tab_home_selected);//更换成首页原来图标bottomBarItem.setStatus(true);//刷新图标cancelTabLoading(bottomBarItem);}},3000);return;}}//如果点击了其他条目BottomBarItem bottomItem = mBottomBarLayout.getBottomItem(0);bottomItem.setIconSelectedResourceId(R.mipmap.tab_home_selected);//更换为原来的图标cancelTabLoading(bottomItem);//停止旋转动画}});/**停止首页页签的旋转动画*/private void cancelTabLoading(BottomBarItem bottomItem) {Animation animation = bottomItem.getImageView().getAnimation();if (animation != null){animation.cancel();}}
实现思路:
1.当点击页签加载的时候,BottomBarItem通过调用setIconSelectedResourceId()设置成选中状态下的图标资源id为加载中图标的资源id,完成图标的更换操作;
2.通过BottomBarItem获取到对应页签的ImageView,对其设置旋转动画,执行旋转动画,当点击其他页签或者数据加载完成后,更换回原来的选中图标,停止旋转动画。
导入方式
在项目根目录下的build.gradle中的allprojects{}中,添加jitpack仓库地址,如下:
allprojects {repositories {jcenter()maven { url 'https://jitpack.io' }//添加jitpack仓库地址}
}
打开app的module中的build.gradle,在dependencies{}中,添加依赖,如下:
dependencies {compile 'com.github.chaychan:BottomBarLayout:1.0.3'
}
好了,到这里BottomBarLayout的介绍就到此为止了,之所以封装这个控件主要是为了方便开发,希望可以帮助到更多人,如果大家有什么想法或者意见不妨向我提出,我会不断完善BottomBarLayout的。
源码地址 https://github.com/chaychan/BottomBarLayout
BottomBarLayout——方便快捷地实现底部导航栏相关推荐
- android自定义底部中间突出导航栏,Android选中突出背景效果的底部导航栏功能
今天在群里看到一个底部导航选中突出效果像这样 就想着 这个应该怎么做呢,我记得类似咸鱼那种的是中间突出,不像这种 是选中哪个,哪个就突出 第一种方法 简单快捷,让UI帮忙切几张带突出背景的图片, 选中 ...
- 转载:Android (争取做到)最全的底部导航栏实现方法
原文出处 标题:Android (争取做到)最全的底部导航栏实现方法 作者:野狼谷 原文链接:Android (争取做到)最全的底部导航栏实现方法 - 野狼谷 - 博客园 前言 本文(争取做到)And ...
- IOS微信下问题1 底部导航栏导致标签位置偏移
何时出现: 在IOS微信浏览器下,当浏览器内出现跳转产生url历史记录的时候,此栏就会出现 导致的问题: 导航栏影响高度计算,此问题很少出现.模拟问题,用户打开一个页面,此时没有历史记录导航栏不存在. ...
- php仿微信底部菜单,Android实现简单底部导航栏 Android仿微信滑动切换效果
Android仿微信滑动切换最终实现效果: 大体思路: 1. 主要使用两个自定义View配合实现; 底部图标加文字为一个自定义view,底部导航栏为一个载体,根据需要来添加底部图标; 2. 底部导航栏 ...
- android 固定底部导航,如何设置android底部导航栏位置固定在android
请帮我设置底部导航栏位置固定在底部, ,因为我在输入editText字段时遇到问题,底部导航栏向上移动并覆盖其他领域如何设置android底部导航栏位置固定在android 代码: xmlns:and ...
- BottomNavigationView+ViewPager+Fragment仿微信底部导航栏
目标: 要实现的界面如下: 此时,我们需要采用BottomNavigationView+ViewPager+Fragment,一点点的说起.首先要在app/build.gradle里添加: imple ...
- Flutter底部导航栏BottomNavigationBar
BottomNavigationBar是底部的导航栏,一般应用在多个视图进行选择.类比于Android的底部导航栏,由Text文本和Icon图标组成. 这里创建一个List为显示内容提供容器: sta ...
- android仿微信的activity平滑水平切换动画,Android实现简单底部导航栏 Android仿微信滑动切换效果...
Android实现简单底部导航栏 Android仿微信滑动切换效果 发布时间:2020-10-09 19:48:00 来源:脚本之家 阅读:96 作者:丶白泽 Android仿微信滑动切换最终实现效果 ...
- react native 的底部导航栏以及跳转页面带参数
不知不觉又过去了一周,这周依旧是用RN来开发APP,中间遇到很多坑,不过这段时间还是忙,慢慢总结吧,写出一点是一点.写博客除了分享,在开始写之前也是自己对于这段时间学习的总结,重新看代码,理顺思路,这 ...
最新文章
- JZOJ 3766. 【BJOI2014】大融合
- [原创] debian 9.3 搭建Jira+Confluence+Bitbucket项目管理工具(三) -- 安装confluence 6.6.1
- pandas 在jupyter notebook时候能用,但在vscode, pycharm不能用
- windows平台编译vlc
- 文件服务器搭建_小型企业文件存储服务器的搭建四部曲
- prettyping.sh: ping 之美
- jquery ajax 调用webservice以及跨域问题
- Python写数据结构:二叉树的创建和遍历
- 二分法查找c语言程序_用C++写二分查找了!【手绘漫画】图解LeetCode之搜索插入位置(LeetCode 35)...
- 智能硬件再下一城:家居
- Inno SetUp中文语言包以及在脚本中使用
- [生存志] 第134节 兵锋十万踏匈奴
- HDU 6438 Buy and Resell 【贪心+思维+优先队列】
- strcpy和strncpy的区别
- 以前端的角度出发做好SEO需要考虑什么
- CF766 ABCDE
- 剑未佩妥,出门已是江湖!聊聊2019学习和工作
- 信号完整性与电源完整性分析 第三版 pdf_反射、串扰、抖动后,我的信号变成什么鬼?...
- OCR识别PDF乱码问题解决
- IDOC 基础篇 ( 一 )
热门文章
- java 32位兼容_Java 32位与64位兼容性
- 多媒体的计算机系统,多媒体计算机系统().PPT
- 【北亚数据恢复】raid损坏导致硬盘灯报警离线,存储无法使用的数据恢复
- 细粒度图像分类(FGVC)---综述
- 「算法」拓扑排序(货真价实,童叟无欺)
- c语言埃尔米特插值思路,【数学建模算法】(26)插值和拟合:埃尔米特(Hermite)插值和样条插值...
- cox(Quaro)对设计的崭新定义,改变我的人生
- Unexpected Exception caught setting 异常解决记录
- 差异表达分析(DEG)时 row.names'里不能有重复的名字 的解决方案
- 项目笔记 【调查问卷】