『Android基础入门』ViewPager+Fragment+BottomNavigationView实现底部导航

👨‍🎓作者简介:一位喜欢写作,计科专业大三菜鸟

🏡个人主页:starry陆离

如果文章有帮到你的话记得点赞👍+收藏💗支持一下哦

在ViewPager与Fragment结合实现多页面滑动的学习上再进一步,记录一下ViewPager+Fragment+BottomNavigationView实现底部导航

  • 1.复习ViewPager的用法
  • 2.复习FragmentPagerAdapter的使用
  • 3.BottomNavigationView的使用
  • 4.ViewPager切换页面与BottomNavigationView的联动
  • 5.Badge(新消息提示,图标右上角红圈)

1.准备工作:创建布局并设置底部菜单

注意是这个控件,有好几个类似的,不要选错了

image-20220929082646786

创建menu文件

新建一个文件夹

image-20220929082839013

选择menu

image-20220929082902905

在menu下新建一个menu资源文件

image-20220929082946328

完成menu文件的新建

image-20220929083106664

创建selector文件

image-20220929083501713

名字随意,尽量规范,root element 选selector

image-20220929083542997

因为有是个导航按键所以就创建四个selector

state属性默认是false状态,所以图片资源设置成灰色。

image-20220929091040719

在menu中引入刚刚创建的selector资源

image-20220929091454024

回到xml文件中引入导航菜单

app:menu="@menu/button_nav_menu"

image-20220929091650860

通过labelVisibilityMode可以设置按钮的显示模式

image-20220929164553690

2.初始化控件

image-20220929182019904

3.创建FragmentPagerAdapter

因为ViewPager本身几乎已被弃用,所有可以看到关于viewpager的两个Adapter方法也是画上了删除线,不过还是可以使用的,不过是不推荐了。因为现在有更强大的viewpager2

image-20220929182050781

4.初始化数据,绑定Adapter和ViewPager

之前的两个Demo中已经写过两次了,不再赘述。

image-20220929182136163

5.viewpager事件监听

通过viewpager事件监听,在onPageSelected(int position)方法中控制导航栏按钮的跟随fragment的选中

image-20220929182227175

6.BottomNavigationView的事件监听

BottomNavigationView的事件监听,在setOnNavigationItemSelectedListener方法中,设置fragment跟随按钮的选中;这样我们就实现了fragment和BottomNavigationView的双向选中。

image-20220929182246872

7.创建Badge

最后我们通过Badge来设置BottomNavigationView按钮上的消息小红点

image-20220929182257187

8.参考资料

36.5-ViewPager+Fragment+bottomNavigationView实现底部导航_哔哩哔哩_bilibili

(11条消息) 底部菜单控件BottomNavigationView的使用_小凡特爱写代码的博客-CSDN博客_bottomnavigationview

(11条消息) Android:BottomNavigationView自定义选中颜色和文字_VoldemortQian的博客-CSDN博客_bottomnavigationview颜色

9.效果展示

ad02

10.Gitee源码

Android_Java_Review: 学习–代码即笔记 (gitee.com)

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

StarAndroid

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值