底部导航栏

  • 一、效果图
  • 二、实现
    • 1、创建Fragment以及布局文件
    • 2、添加FragmentContainerView和BottomNavigationView两个控件
    • 3、配置xml资源文件
    • 4、给BottomNavigationView配置NavController

一、效果图

使用jetpack的Navigation导航组件和控件BottomNavigationView结合实现app底部导航栏的效果:

二、实现

1、创建Fragment以及布局文件

首先创建四个Fragment,以及对应的布局文件,fragment的布局文件中放一个TextView和修改背景颜色来区别每个fragment。

package com.example.navigationdemo.Testimport android.os.Bundle
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.fragment.app.Fragment
import com.example.navigationdemo.Rclass HomeFragment:Fragment() {override fun onCreateView(inflater: LayoutInflater,container: ViewGroup?,savedInstanceState: Bundle?): View? {super.onCreateView(inflater, container, savedInstanceState)val view = inflater.inflate(R.layout.home_fragment,container,false)return view}
}
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:background="#03A9F4"><TextViewandroid:id="@+id/textView2"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="首页"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>

2、添加FragmentContainerView和BottomNavigationView两个控件

在主Activity的布局文件中加入FragmentContainerView控件,该控件用于交替显示fragment,相当于一个显示fragment的容器。然后再添加BottomNavigationView控件,这个控件就是用来实现底部导航栏的。

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns: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"><androidx.fragment.app.FragmentContainerViewandroid:id="@+id/nav_host_fragment"android:name="androidx.navigation.fragment.NavHostFragment"android:layout_width="0dp"android:layout_height="0dp"app:defaultNavHost="true"app:layout_constraintBottom_toBottomOf="@+id/bottomNavigationView"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintHorizontal_bias="0.0"app:layout_constraintStart_toStartOf="parent"app:layout_constraintTop_toTopOf="parent"app:layout_constraintVertical_bias="0.0"app:navGraph="@navigation/nav_test" /><com.google.android.material.bottomnavigation.BottomNavigationViewandroid:id="@+id/bottomNavigationView"android:layout_width="match_parent"android:layout_height="wrap_content"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintEnd_toEndOf="parent"app:layout_constraintStart_toStartOf="parent"app:menu="@menu/bottom_navigation_menu" /></androidx.constraintlayout.widget.ConstraintLayout>

3、配置xml资源文件

添加完上面两个控件后,就得给它们配置资源文件了。
BottomNavigationView需要一个menu资源文件,在res目录下创建menu目录,然后创建一个xml资源文件bottom_navigation_menu.xml ,在该xml中,就可以配置底部导航栏的四个导航按钮了,包括显示的文字,图标以及id。

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:android="http://schemas.android.com/apk/res/android"><itemandroid:id="@+id/home_page"android:icon="@drawable/ic_search_black_24dp"android:title="首页" /><itemandroid:id="@+id/search_page"android:icon="@drawable/ic_search_black_24dp"android:title="搜索" /><itemandroid:id="@+id/share_page"android:icon="@drawable/ic_search_black_24dp"android:title="分享" /><itemandroid:id="@+id/mine_page"android:icon="@drawable/ic_search_black_24dp"android:title="我的" /></menu>

下一步就是给FragmentContainerView控件配置导航图资源,如果你还没用过jetpack的Navigation导航组件,你可以看一下我写的这篇文章:
Android Jetpack 导航组件Navigation使用入门
创建navigation资源目录,在该目录下创建导航图xml文件nav_test.xml ,在文件中你需要添加四个< fragment >标签,配置它们的id以及name属性,然后这里要注意一点:< fragment >标签的id要和bottom_navigation_menu.xml 中item的id一致,这样它才能知道哪个item对应哪个fragment。

<?xml version="1.0" encoding="utf-8"?>
<navigation xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/nav_test.xml"app:startDestination="@id/home_page"><fragmentandroid:id="@+id/home_page"android:name="com.example.navigationdemo.Test.HomeFragment"android:label="HomeFragment" /><fragmentandroid:id="@+id/mine_page"android:name="com.example.navigationdemo.Test.MineFragment"android:label="MineFragment" /><fragmentandroid:id="@+id/search_page"android:name="com.example.navigationdemo.Test.SearchFragment"android:label="SearchFragment" /><fragmentandroid:id="@+id/share_page"android:name="com.example.navigationdemo.Test.ShareFragment"android:label="ShareFragment" /></navigation>

4、给BottomNavigationView配置NavController

这是最重要的一步,在代码中给BottomNavigationView控件设置一个NavController,NavController是用来控制NavHostFragment中交替显示fragment的。在代码中可以去fragment管理器里通过id找到NavHostFragment,然后再获取到相应的NavController。

package com.example.navigationdemo.Testimport android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import androidx.navigation.findNavController
import androidx.navigation.fragment.NavHostFragment
import androidx.navigation.ui.setupWithNavController
import com.example.navigationdemo.R
import kotlinx.android.synthetic.main.activity_test.*class TestActivity:AppCompatActivity() {override fun onCreate(savedInstanceState: Bundle?) {super.onCreate(savedInstanceState)setContentView(R.layout.activity_test)initView()}private fun initView() {//让BottomNavigationView与NavController相关联//方法一:去fragment管理器里通过id找到NavHostFragmentval navHostFragment = supportFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragmentbottomNavigationView.setupWithNavController(navHostFragment.navController)//方法二:把androidx.fragment.app.FragmentContainerView改成fragment//val navController = findNavController(R.id.nav_host_fragment)//bottomNavigationView.setupWithNavController(navController)}
}

上面代码注释中还有第二种方法让BottomNavigationView与NavController相关联,但需要将androidx.fragment.app.FragmentContainerView改成fragment

至此就实现底部导航栏的功能了。

Android Navigation与BottomNavigationView实现底部导航栏相关推荐

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

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

  2. php点击切换图片的底部导航,如何优雅地使用BottomNavigationView实现底部导航栏+fragment切换效果...

    BottomNavigationView.jpeg 引言 之前总是使用RadioButton+ViewPager来实现底部导航栏+fragment切换效果,总是繁琐地还需要写ViewPager的适配器 ...

  3. android开发时华为手机底部导航栏挡住了应用布局

    原因:使用安卓的BottomNavigationView控件开发底部导航栏同时使用了沉浸式状态栏导致华为手机的底部导航栏会盖住我应用的导航栏. 解决:先写一个工具类 import android.co ...

  4. android radiobutton底部导航,android中Fragment+RadioButton实现底部导航栏

    在App中经常看到这样的tab底部导航栏 那么这种效果是如何实现,实现的方式有很多种,最常见的就是使用Fragment+RadioButton去实现.下面我们来写一个例子 首先我们先在activity ...

  5. android获取刘海屏状态栏高度,Android刘海屏全面屏底部导航栏的适配

    关于Android状态栏和虚拟导航栏的适配,文章:https://blog.csdn.net/leogentleman/article/details/54566319 讲的很不错. 状态栏的适配: ...

  6. 在android Studio中设计app的底部导航栏

    准备工作 新建一个空白android项目 命名为csdn 在res/layout路径下设置主页面 使用线性布局 linearLayout 使用自定义的viewPager(切换多个页面会秒跳转,提升体验 ...

  7. android底部导航栏选中动画,Android选中突出背景效果的底部导航栏功能

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

  8. Android商城开发--实现商城底部导航栏

    让我们先看效果图: 图一是默认效果图,图二是点击首页的效果图(图标和字体颜色会变化)            接下来是实现方法 1.先写布局. 我新建了一个ShoppingActivity,在activ ...

  9. Android 泽宇三种底部导航栏

    compile 'com.flyco.tablayout:FlycoTabLayout_Lib:2.0.8@aar'//底部导航 <com.flyco.tablayout.CommonTabLa ...

最新文章

  1. Hexo+OSChina(码云)+git 搭建个人博客
  2. bzoj4033:[HAOI2015]树上染色
  3. PHP微信开发框架LaneWeChat框架简介
  4. pg加密扩展的安装_为编译安装的PG安装扩展
  5. python查看运行内存占用_python中使用psutil查看内存占用的情况
  6. 管理动物园动物c++_中国动物园行业供需预测及投资潜力分析
  7. ios捕捉键盘view
  8. 房产管理信息系统 oracle,房地产企业项目信息管理系统|案场管理系统
  9. 已解决:An error occurred at line: 1 in the generated java file The type java.io.ObjectInputStream canno
  10. WES7 SKU WES7E和WES7P的区别
  11. 服务器系统万能驱动,IT天空万能驱动程序
  12. Computer programming and database - 方方面面入门
  13. 研究生必须过计算机和英语吗,2020考研:英语一75分,她是怎么做到的_计算机考研科目...
  14. Codeforces 897C Nephren gives a riddle(DFS)
  15. 2023年网络安全比赛--跨站脚本攻击①中职组(超详细)
  16. c语言中 指针的研究,C语言中指针的研究与总结
  17. 软件项目管理课程复习题
  18. (CVPR-2021)RepVGG:极简架构,SOTA性能,让VGG式模型再次伟大
  19. 初识HTTP中的Referer
  20. 京东H5小游戏《疯狂足球》Android外挂实现

热门文章

  1. 使用计算机的成本包括哪些,课题经费预算其他费用包括哪些
  2. mysql数据设置有效期_zabbix管理六之数据有效期设置
  3. ubuntu上打开markdown文件
  4. 原理图库:元器件引脚命名如何输出上划线
  5. 【RPA自动化】selenium教程_元素定位及表格读取
  6. Audacity如何改变音频节奏?Audacity调整音频节奏方法
  7. 数值分析matlab最小二乘法,数值分析 最小二乘 matlab
  8. win8系统桌面计算机,Win8计算机桌面管理软件
  9. python写的2048游戏,源代码,pygame
  10. 博途SCL模板项目实例,SCL学习资料,SCL详细资料,SCL教程