文章目录

  • 实现效果图
  • 前言
  • XML布局
  • menu文件
  • ViewPager的使用
    • PagerAdapter(Java)
    • Activity中实现
  • 上下联动
    • 侧滑带动按钮选择
    • 点击底部按钮带动页面
  • 自定义选中&未选中颜色
    • color文件
    • 创建color文件
  • 结语

实现效果图

前言

微信相信每个人都用,不得不说微信界面的整洁度、体验感还是挺好的,那么微信底部的导航是怎样实现的呢?怎样做成点击底部导航栏可以进行页面切换、左右划也可以实现同样的效果呢?今天就带大家来仿制一个,高仿哟!

XML布局

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><androidx.viewpager.widget.ViewPagerandroid:id="@+id/viewpager"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_weight="1" /><com.google.android.material.bottomnavigation.BottomNavigationViewandroid:id="@+id/bn_view"android:layout_width="match_parent"android:layout_height="wrap_content" /></LinearLayout>

menu文件

这里我们需要先在 res 目录下新建一个 menu 文件夹来放 menu 文件

然后我们需要新建一个 menu 文件,icon代表底部导航的图标、title代表底部导航的文字

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"><itemandroid:id="@+id/first"android:icon="@mipmap/img_left"android:title="第一个" /><itemandroid:id="@+id/second"android:icon="@mipmap/img_up"android:title="第二个" /><itemandroid:id="@+id/third"android:icon="@mipmap/img_down"android:title="第三个" /></menu>

menu文件写好了以后,记得把他加到XML控件上去:menu

<com.google.android.material.bottomnavigation.BottomNavigationViewapp:menu="@menu/bn_view"android:id="@+id/bn_view"android:layout_width="match_parent"android:layout_height="wrap_content" />

如图所示,这就是加上menu后的效果,这里需要注意的是,你加的icon会自动变成这种只有外观轮廓的样子

ViewPager的使用

想要实现ViewPager,你得现有一个Adapter适配器,这边getItem()方法你需要返回你当前List中和当前position对应的元素(也就是Fragment页面),getCount()就比较简单了,直接返回List的大小就行了。

PagerAdapter(Java)
public class PagerAdapter extends FragmentPagerAdapter {private List<Fragment> mList;public PagerAdapter(@NonNull FragmentManager fm, List<Fragment> list) {super(fm);mList = list;}public PagerAdapter(@NonNull FragmentManager fm, int behavior, List<Fragment> list) {super(fm, behavior);mList = list;}public PagerAdapter(@NonNull FragmentManager fm) {super(fm);}@NonNull@Overridepublic Fragment getItem(int position) {return mList.get(position);}@Overridepublic int getCount() {return mList.size();}
}
Activity中实现

只需要在List中随便加入几个Fragment,然后实例化刚刚写的PagerAdapter,最后ViewPager调用 .setAdapter() 方法传入PagerAdapter即可实现一个可以左右侧滑切换界面的效果

注意:你传入多少个Fragment取决于你menu的数量

List<Fragment> list = new ArrayList<>();// 随便加了三个有内容的Fragmentlist.add(new FragmentTabFrag1());list.add(new FragmentEventBus());list.add(new FragmentEventBus2());PagerAdapter adapter = new PagerAdapter(getSupportFragmentManager(), list);mViewpager.setAdapter(adapter);

做完这些,你会发现,上面可以切换界面的做好了,下面的导航也实现了,可是它两却互不相关,你点你的,我滑我的。。。那么接下来就来让它两“心连心”。

上下联动

侧滑带动按钮选择

先实现一下,我ViewPager侧滑,可以改变BottomNavigationView的当前选项

只需给你的ViewPager加上一个PageChangeListener(页面改变监听器),然后在页面改变以后,BottomNavigationView调用.setSelectedItemId()方法,手动对当前选项作出对应的改变,就实现了!

mViewpager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {switch (position) {case 0:mBnView.setSelectedItemId(R.id.first);break;case 1:mBnView.setSelectedItemId(R.id.second);break;case 2:mBnView.setSelectedItemId(R.id.third);break;}}@Overridepublic void onPageScrollStateChanged(int state) {}
});
点击底部按钮带动页面

页面侧滑带动按钮实现了,就剩下按钮带动页面了

这里也是非常的简单,只需要给BottomNavigationView加上一个ItemSelectedListener(子项选择监听器),然后根据子项的改变,然后ViewPager调用.setCurrentItem()方法对当前显示的页面进行更改;点击按钮以后,页面跟着动的效果也就实现了。

mBnView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {@Overridepublic boolean onNavigationItemSelected(@NonNull MenuItem menuItem) {switch (menuItem.getItemId()) {case R.id.first:mViewpager.setCurrentItem(0);break;case R.id.second:mViewpager.setCurrentItem(1);break;case R.id.third:mViewpager.setCurrentItem(2);break;}return true;}
});

做到这里,效果图中的功能就实现了,只不过颜色可能不是那么令人喜欢,作为一个完美主义,怎能容忍?改颜色!改它!

自定义选中&未选中颜色

color文件

在res目录下创建color文件夹,没办法,它就是这么刁钻,用这个控件创建了2个文件夹

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZOvHJb42-1589884552962)(E:\ASYU\Desktop\color创建.png)]

创建color文件

我这里用了红绿两种颜色,红色是未选中时的颜色,绿色是选中时的颜色

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:color="@color/colorRed" android:state_checked="false" /><item android:color="@color/colorGreen" android:state_checked="true" /></selector>

然后自然是在XML中加上属性:itemIconTint

<com.google.android.material.bottomnavigation.BottomNavigationViewapp:itemIconTint="@color/bn_view"app:menu="@menu/bn_view"android:id="@+id/bn_view"android:layout_width="match_parent"android:layout_height="wrap_content" />

结语

我想着有个前言,没个结语好像不太协调。。。

来都来了,点个赞再走呗~

3分钟教你实现仿微信底部导航栏效果(BottomNavigationView + ViewPager)相关推荐

  1. JFTabBar android强大的底部导航栏框架 (微信底部导航栏效果)

    TabBar这个名字相信很多学过一点IOS程序员都知道它是用来干嘛的,但本人也并非擅长开发IOS程序员,只是略懂略懂....这是一个很强大的TabBar,可满足很多需求.用起来也非常简单,在oncre ...

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

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

  3. android 微信底部渐变,仿微信底部导航栏BottomNavigation渐变色

    ezgif.com-video-to-gif.gif 不说废话了,直接上代码: 自定义View /** * * author : Harvey * time : 2018/06/14 * desc : ...

  4. android 底部tab效果,Android 仿微信底部渐变Tab效果

    先来看一下效果图 除了第三个的发现Tab有所差别外,其他的基本还原了微信的底部Tab渐变效果 每个Tab都是一个自定义View,根据ImageView的tint属性来实现颜色渐变效果,tint属性的使 ...

  5. 微信底部导航栏动画实现

    微信底部导航栏动画实现 Android大神郭霖的公众号中关于微信底部动画实现的更新 Android大神郭霖的公众号中关于微信底部动画实现的更新 郭霖老师的代码里还是support库,我更新成了Andr ...

  6. android仿咸鱼底部导航栏,Flutter沉浸式状态栏/AppBar导航栏/仿咸鱼底部凸起导航栏效果...

    如下图:状态栏是指android手机顶部显示手机状态信息的位置. android 自4.4开始新加入透明状态栏功能,状态栏可以自定义颜色背景,使titlebar能够和状态栏融为一体,增加沉浸感. 如上 ...

  7. Android仿Qzone底部导航栏加号弹出菜单

    最近看到QQ空间 新浪微博-.好多应用底部导航栏都有加号点击弹出菜单,于是就写了一个demo,来给没做过这个功能的小伙伴一个参考,希望对大家有所帮助,demo中的图片均来源于Qzone 仅作为学习交流 ...

  8. 【Android】底部导航栏【BottomNavigationView】+【ViewPage2】

    问题需求 实现底部导航栏切换 问题解决 最简单的实现方式就是使用系统自动生成的模板页面,但是有时候会有一些问题,特别是需要去除[ActionBar]的情况下,这种情况下使用系统的模板页面就不好用了,此 ...

  9. android底部导航栏下沉,【详细】手把手教你快速实现Android底部导航栏

    1. 实现底部的Tab,自定义TabContainerView 继承 RelativeLayout,这是我们最终封装的View工具类.其内部主要由viewpager和底部的TabHost类组成. Vi ...

最新文章

  1. iOS APP配置HTTPS流程
  2. before css 旋转_七夕,当然少不了纯CSS的点缀啦
  3. Ubuntu下安装vscode c++环境
  4. 地图投影系列介绍(四)----投影坐标系
  5. php 清空一个数组_PHP工程师学Python数据类型
  6. 1947-2021 NBA总冠军次数排行榜
  7. 三个等于号===和两个等于号==的区别
  8. Java为何能一次编写,到处运行
  9. 使用NVIDIA端到端深度学习平台进行缺陷自动检测
  10. oracle自定义排序规则_Excel的排序方法,你会几种?
  11. Delphi2010 Dll 函数列表查看
  12. 苹果手机运行html游戏,苹果手机如何运行PSP游戏方法
  13. oracle排列组合,Oracle SQL排列组合之排列问题
  14. [论文笔记]Rob-GAN: Generator, Discriminator, and Adversarial Attacker
  15. 模模搭升级,场景自动同步ThingJS平台,搭建开发无缝衔接!
  16. (转)逃脱者可获生机(上)
  17. linux kernal pwn STARCTF 2019 hackme(三)userfaultfd机制修改cred
  18. 读书笔记:不可能的技艺,巅峰人生需要凶猛的起点
  19. 阴天(唐伯虎点秋香版)2铃声 阴天(唐伯虎点秋香版)2手机铃声免...
  20. jsp分页功能的实现

热门文章

  1. 2021年Web开发的7大趋势
  2. 安卓一键清理内存_米财清理星手机版下载-米财清理星安卓版 v1.5.0免费版
  3. 苹果linux桌面文件夹,Linux下打造仿Mac系统桌面
  4. 西数黑盘升级:仍非单碟1TB
  5. 计算机培训spss,[计算机软件及应用]SPSS 统计软件培训.ppt
  6. 12月书讯 | 年末上新,好书不断
  7. 拆卸组装计算机的注意事项,自己动手组装电脑要注意什么 小白装机必修功课...
  8. 当ViewModelProviders方法被弃用,使用ViewModelProvider获取ViewModel的新写法_莫韵乐与bug的奇妙冒险
  9. RAP2 接口Mock工具部署使用
  10. 糖尿病足最新研究成果进展(2021年)