Android底部导航栏BottomNavigatonView的使用方式

BottomNavigationView

今天创建工程的时候无意间点到了Bottom Navigatoin Activity于是就四处学习了解了一下,写一篇文章,以免自己忘记。

第一步

你可以直接使用studio自带的创建一个Activity,new-Activity-Bottom Navigation Activity创建一个Activity。
Android底部导航栏BottomNavigatonView的使用方式_第1张图片
Android底部导航栏BottomNavigatonView的使用方式_第2张图片
你会发现系统自动给创建好了模板,特别注意的是res文件夹下的menu菜单,多了一个navigation.xml




    

    

    


Activity的xml文件里面BottomNavigationView的代码

    

Activity中的代码

private TextView mTextMessage;

    private BottomNavigationView.OnNavigationItemSelectedListener mOnNavigationItemSelectedListener
            = new BottomNavigationView.OnNavigationItemSelectedListener() {

        @Overridei
        public boolean onNavigationItemSelected(@NonNull MenuItem item) {
            switch (item.getItemId()) {
                case R.id.navigation_home:
                    mTextMessage.setText(R.string.title_home);
                    return true;
                case R.id.navigation_dashboard:
                    mTextMessage.setText(R.string.title_dashboard);
                    return true;
                case R.id.navigation_notifications:
                    mTextMessage.setText(R.string.title_notifications);
                    return true;
            }
            return false;
        }
    };

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);

        mTextMessage = (TextView) findViewById(R.id.message);
        BottomNavigationView navigation = (BottomNavigationView) findViewById(R.id.navigation);
        navigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener);
    }

运行一下,显示的效果都是默认的。按照我们自己的需求,我们将会对的文字和图片进行修改,还有文字和图片的颜色。

第二步,了解一下Vector Asset的使用

BottomNavigationView里面添加的图片都是使用的xml的格式
其中的一个图片示例


    

Android底部导航栏BottomNavigatonView的使用方式_第3张图片
首先制作这样的图片对格式是又要求的
点击drawable-new-Vector Asset

Asset Type选择使用系统的图片还是本地文件,本地文件的格式要求问SVG和PSD的,下面讲解的是添加自己的本地图片,你也可以选择Clip Art中的其他系统图片。
Android底部导航栏BottomNavigatonView的使用方式_第4张图片
然后点击Local file,选择已经准备好的svg的图片,点击next和finish即可创建一个vector类型的图片
Android底部导航栏BottomNavigatonView的使用方式_第5张图片
Android底部导航栏BottomNavigatonView的使用方式_第6张图片
在你的drawable文件夹里面就会出现ic_marker.xml的一张图片,打开后是这个样子


    
    

Android底部导航栏BottomNavigatonView的使用方式_第7张图片

第三步,假设你已经准备好了三张图片

然后更新menu中的navigation.xml,设置icon属性为你自己的图片,title为下方显示的文字




    

    

    


预览后的效果
Android底部导航栏BottomNavigatonView的使用方式_第8张图片
发现已经成功的换成了自己的图片

第四步,更改点击和没有点击时的颜色

点击包名-New-Android Resource File
Android底部导航栏BottomNavigatonView的使用方式_第9张图片
Resource type选择Drawable,写好文件名,点击OK
Android底部导航栏BottomNavigatonView的使用方式_第10张图片
打开main2_selector.xml文件显示一下代码





想要更改颜色需要添加下面两句话,这样颜色选择文件就写好了



	
    
    
    

color.xml 中的代码



  	......
    #ff0000
    #00ff00

最后在Activity的xml文件里的BottomNavigationView组件中添加图片和文字的颜色属性


这样就是实现了颜色的更改,效果如下
Android底部导航栏BottomNavigatonView的使用方式_第11张图片

注意:如果里面的图标超过了三个

如果图标超过了三个,需要在BottomNavigationView组件中添加属性,不然就会只显示选中的图片下的文字,就像这样:
在这里插入图片描述


labelVisibilityMode中的属性值:
labeled : 保持所有文字便签显示
unlabeled :只显示图标
selected :在选中的时候显示文字标签,有动画效果
auto : 在 1-3 个按钮时使用 labeled ,大于 3 个按钮使用 selected

最后,如果你创建的是一个Empty Activity

你需要创建一个menu文件夹和一个menu.xml
在res上右键new-Directory 命名问menu
Android底部导航栏BottomNavigatonView的使用方式_第12张图片
然后在menu文件夹上右键new-Menu resource file输入文件名,点击ok即可。
然后照上述步骤添加相应的代码。
Android底部导航栏BottomNavigatonView的使用方式_第13张图片

你可能感兴趣的:(Android)