转载请注明出处: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——方便快捷地实现底部导航栏相关推荐

  1. android自定义底部中间突出导航栏,Android选中突出背景效果的底部导航栏功能

    今天在群里看到一个底部导航选中突出效果像这样 就想着 这个应该怎么做呢,我记得类似咸鱼那种的是中间突出,不像这种 是选中哪个,哪个就突出 第一种方法 简单快捷,让UI帮忙切几张带突出背景的图片, 选中 ...

  2. 转载:Android (争取做到)最全的底部导航栏实现方法

    原文出处 标题:Android (争取做到)最全的底部导航栏实现方法 作者:野狼谷 原文链接:Android (争取做到)最全的底部导航栏实现方法 - 野狼谷 - 博客园 前言 本文(争取做到)And ...

  3. IOS微信下问题1 底部导航栏导致标签位置偏移

    何时出现: 在IOS微信浏览器下,当浏览器内出现跳转产生url历史记录的时候,此栏就会出现 导致的问题: 导航栏影响高度计算,此问题很少出现.模拟问题,用户打开一个页面,此时没有历史记录导航栏不存在. ...

  4. php仿微信底部菜单,Android实现简单底部导航栏 Android仿微信滑动切换效果

    Android仿微信滑动切换最终实现效果: 大体思路: 1. 主要使用两个自定义View配合实现; 底部图标加文字为一个自定义view,底部导航栏为一个载体,根据需要来添加底部图标; 2. 底部导航栏 ...

  5. android 固定底部导航,如何设置android底部导航栏位置固定在android

    请帮我设置底部导航栏位置固定在底部, ,因为我在输入editText字段时遇到问题,底部导航栏向上移动并覆盖其他领域如何设置android底部导航栏位置固定在android 代码: xmlns:and ...

  6. BottomNavigationView+ViewPager+Fragment仿微信底部导航栏

    目标: 要实现的界面如下: 此时,我们需要采用BottomNavigationView+ViewPager+Fragment,一点点的说起.首先要在app/build.gradle里添加: imple ...

  7. Flutter底部导航栏BottomNavigationBar

    BottomNavigationBar是底部的导航栏,一般应用在多个视图进行选择.类比于Android的底部导航栏,由Text文本和Icon图标组成. 这里创建一个List为显示内容提供容器: sta ...

  8. android仿微信的activity平滑水平切换动画,Android实现简单底部导航栏 Android仿微信滑动切换效果...

    Android实现简单底部导航栏 Android仿微信滑动切换效果 发布时间:2020-10-09 19:48:00 来源:脚本之家 阅读:96 作者:丶白泽 Android仿微信滑动切换最终实现效果 ...

  9. react native 的底部导航栏以及跳转页面带参数

    不知不觉又过去了一周,这周依旧是用RN来开发APP,中间遇到很多坑,不过这段时间还是忙,慢慢总结吧,写出一点是一点.写博客除了分享,在开始写之前也是自己对于这段时间学习的总结,重新看代码,理顺思路,这 ...

最新文章

  1. JZOJ 3766. 【BJOI2014】大融合
  2. [原创] debian 9.3 搭建Jira+Confluence+Bitbucket项目管理工具(三) -- 安装confluence 6.6.1
  3. pandas 在jupyter notebook时候能用,但在vscode, pycharm不能用
  4. windows平台编译vlc
  5. 文件服务器搭建_小型企业文件存储服务器的搭建四部曲
  6. prettyping.sh: ping 之美
  7. jquery ajax 调用webservice以及跨域问题
  8. Python写数据结构:二叉树的创建和遍历
  9. 二分法查找c语言程序_用C++写二分查找了!【手绘漫画】图解LeetCode之搜索插入位置(LeetCode 35)...
  10. 智能硬件再下一城:家居
  11. Inno SetUp中文语言包以及在脚本中使用
  12. [生存志] 第134节 兵锋十万踏匈奴
  13. HDU 6438 Buy and Resell 【贪心+思维+优先队列】
  14. strcpy和strncpy的区别
  15. 以前端的角度出发做好SEO需要考虑什么
  16. CF766 ABCDE
  17. 剑未佩妥,出门已是江湖!聊聊2019学习和工作
  18. 信号完整性与电源完整性分析 第三版 pdf_反射、串扰、抖动后,我的信号变成什么鬼?...
  19. OCR识别PDF乱码问题解决
  20. IDOC 基础篇 ( 一 )

热门文章

  1. java 32位兼容_Java 32位与64位兼容性
  2. 多媒体的计算机系统,多媒体计算机系统().PPT
  3. 【北亚数据恢复】raid损坏导致硬盘灯报警离线,存储无法使用的数据恢复
  4. 细粒度图像分类(FGVC)---综述
  5. 「算法」拓扑排序(货真价实,童叟无欺)
  6. c语言埃尔米特插值思路,【数学建模算法】(26)插值和拟合:埃尔米特(Hermite)插值和样条插值...
  7. cox(Quaro)对设计的崭新定义,改变我的人生
  8. Unexpected Exception caught setting 异常解决记录
  9. 差异表达分析(DEG)时 row.names'里不能有重复的名字 的解决方案
  10. 项目笔记 【调查问卷】