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

实现效果图

在这里插入图片描述

前言

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

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.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1" />

    <com.google.android.material.bottomnavigation.BottomNavigationView
        android: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">

    <item
        android:id="@+id/first"
        android:icon="@mipmap/img_left"
        android:title="第一个" />
    <item
        android:id="@+id/second"
        android:icon="@mipmap/img_up"
        android:title="第二个" />
    <item
        android:id="@+id/third"
        android:icon="@mipmap/img_down"
        android:title="第三个" />

</menu>

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

<com.google.android.material.bottomnavigation.BottomNavigationView
        app: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
    @Override
    public Fragment getItem(int position) {
        return mList.get(position);
    }

    @Override
    public int getCount() {
        return mList.size();
    }
}
Activity中实现

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

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

List<Fragment> list = new ArrayList<>();
        // 随便加了三个有内容的Fragment
        list.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() {
    @Override
    public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

    }

    @Override
    public 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;
        }
    }

    @Override
    public void onPageScrollStateChanged(int state) {

    }
});
点击底部按钮带动页面

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

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

mBnView.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {
    @Override
    public 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.BottomNavigationView
        app:itemIconTint="@color/bn_view"
        app:menu="@menu/bn_view"
        android:id="@+id/bn_view"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

在这里插入图片描述

结语

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

来都来了,点个赞再走呗~
在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章