博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android应用-底部导航栏的使用
阅读量:4663 次
发布时间:2019-06-09

本文共 2716 字,大约阅读时间需要 9 分钟。

目录

  • 底部导航栏是基于Bottom Navigation Bar 插件使用的
  • 这个插件包裹在com.android.support:design:28.0.0,必须引入

1. 设计底部导航栏页面

1.1. 创建必须的文件夹

  • 在res下创建color和menu文件夹

color文件夹: 用于存放导航栏的个性化颜色

menu文件夹: 用于存放导航栏的子项

1.2. 设计主页面

  • 首先设计子项: menu下新建nav_items.xml文件
  • 设计个性化颜色,color文件夹下新建nav_item_color.xml
  • 然后再主页面中引入子项 ,在activity_main.xml

2. 设计逻辑函数

点击每个子项都可以跳转到对应的页面上去

  • 首先创建三个fragment: MainFragment, SearchFragment, AccountFragment
  • 然后再主页面中写逻辑函数
package com.example.myapplication;import android.support.annotation.NonNull;import android.support.design.widget.BottomNavigationView;import android.support.v4.app.Fragment;import android.support.v4.app.FragmentTransaction;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.MenuItem;import android.widget.FrameLayout;public class MainActivity extends AppCompatActivity {    private BottomNavigationView mMainNav;    private FrameLayout mMainFrame;    private HomeFragment homeFragment;    private SearchFragment searchFragment;    private AccountFragment accountFragment;    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        mMainFrame = (FrameLayout)findViewById(R.id.main_frame);        mMainNav = (BottomNavigationView)findViewById(R.id.main_nav);        homeFragment = new HomeFragment();        searchFragment = new SearchFragment();        accountFragment = new AccountFragment();        // 设置默认的fragment        setFragment(homeFragment);        mMainNav.setOnNavigationItemSelectedListener(new BottomNavigationView.OnNavigationItemSelectedListener() {            @Override            public boolean onNavigationItemSelected(@NonNull MenuItem menuItem) {                switch (menuItem.getItemId()){                    case R.id.nav_homes:                        setFragment(homeFragment);                        return true;                    case R.id.nav_searchs:                        setFragment(searchFragment);                        return true;                    case R.id.nav_accounts:                        setFragment(accountFragment);                        return true;                    default:                        return false;                }            }        });    }//    根据传入的framgment对象,对现在设置新的fragment    private void setFragment(Fragment fragment) {        FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction();        fragmentTransaction.replace(R.id.main_frame, fragment);        fragmentTransaction.commit();    }}

3. 项目展示

o_4.gif

转载于:https://www.cnblogs.com/haochen273/p/10797752.html

你可能感兴趣的文章
左右固定,中间自适应的三栏式布局五种写法
查看>>
存一些可能会用得到的vue的UI框架
查看>>
MySql随笔part4 数据操作
查看>>
WPF MultiDataTrigger
查看>>
(CSDN迁移)js中的判空
查看>>
centos7上安装mysql说明
查看>>
Redis几个认识误区
查看>>
SQL Server 2008系统信息查询常用命令 查看表大小、记录数等
查看>>
Python学习 :常用模块(一)
查看>>
DirectFB 之 实例图像不断右移
查看>>
About The User Guide
查看>>
测试随笔
查看>>
20145324王嘉澜《网络对抗技术》 信息搜集与漏洞扫描
查看>>
[bzoj4849][Neerc2016]Mole Tunnels
查看>>
UI和UX的10个不同点
查看>>
开篇辞
查看>>
python的globals()
查看>>
Asp.net MVC重要
查看>>
centos安装python3
查看>>
流与缓冲区的理解
查看>>