一、效果图展示

如果动图没有动的话,也可以看下面这个静态图

以下挨个分析每个的实现,这里只做简单的效果展示,大家可以基于目前代码做二次开发。

二、BottomNavigationView

这是 Google 给我们提供的一个专门用于底部导航的 View,你只需要在新建 Activity 的时候选择 “Bottom Navigation Activity”,IDE 就会自动使用 BottomNavigationView 帮你生成好相应的代码了。

1. 在 xml 中使用

 <android.support.design.widget.BottomNavigationViewandroid:id="@+id/navigation"android:layout_width="0dp"android:layout_height="wrap_content"android:layout_marginEnd="0dp"android:layout_marginStart="0dp"android:background="?android:attr/windowBackground"app:layout_constraintBottom_toBottomOf="parent"app:layout_constraintLeft_toLeftOf="parent"app:layout_constraintRight_toRightOf="parent"app:menu="@menu/navigation" / 

这里面唯一要注意的就是 app:menu 属性了,它指定了你的导航栏显示的页面菜单是怎样的。

2. menu 的布局文件

<?xml version="1.0" encoding="utf-8"?
<menu xmlns:android="http://schemas.android.com/apk/res/android" <itemandroid:id="@+id/navigation_home"android:icon="@drawable/ic_home_black_24dp"android:title="@string/title_home" / <itemandroid:id="@+id/navigation_dashboard"android:icon="@drawable/ic_dashboard_black_24dp"android:title="@string/title_dashboard" / <itemandroid:id="@+id/navigation_notifications"android:icon="@drawable/ic_notifications_black_24dp"android:title="@string/title_notifications" / </menu 

3. 在 Activity 中调用

 private TextView mTextMessage;private BottomNavigationView.OnNavigationItemSelectedListener mOnNavigationItemSelectedListener= new BottomNavigationView.OnNavigationItemSelectedListener() {@Overridepublic 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;}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_style1);mTextMessage = findViewById(R.id.message);BottomNavigationView navigation = findViewById(R.id.navigation);navigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener);}

这里的演示 code 都是 IDE 自动生成的,由于 BottomNavigationView 目前我还没有在项目中实际使用过,这里不做过多分析,使用起来不难,以上代码已经足以满足我们的基本使用要求了。

三、RadioGroup + ViewPager

这是一种比较常见了的,下面 4 个 tab 的导航按钮,可以切换不同的页面,这里页面使用了 ViewPager + Fragment 的组合,实现了滑动的页面效果,也可以不使用 ViewPager,这个根据产品的定义来使用即可。

1. 布局文件

<?xml version="1.0" encoding="utf-8"?
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".style2.Style2Activity" <android.support.v4.view.ViewPagerandroid:id="@+id/fragment_vp"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_above="@+id/tabs_rg" / <RadioGroupandroid:id="@+id/tabs_rg"android:layout_width="match_parent"android:layout_height="56dp"android:layout_alignParentBottom="true"android:background="#dcdcdc"android:orientation="horizontal" <RadioButtonandroid:id="@+id/today_tab"style="@style/Custom.TabRadioButton"android:checked="true"android:drawableTop="@drawable/tab_sign_selector"android:text="今日" / <RadioButtonandroid:id="@+id/record_tab"style="@style/Custom.TabRadioButton"android:drawableTop="@drawable/tab_record_selector"android:text="记录" / <RadioButtonandroid:id="@+id/contact_tab"style="@style/Custom.TabRadioButton"android:drawableTop="@drawable/tab_contact_selector"android:text="通讯录" / <RadioButtonandroid:id="@+id/settings_tab"style="@style/Custom.TabRadioButton"android:drawableTop="@drawable/tab_setting_selector"android:text="设置" / </RadioGroup
</RelativeLayout 

2. Activity 类

public class Style2Activity extends AppCompatActivity {private ViewPager mViewPager;private RadioGroup mTabRadioGroup;private List<Fragment  mFragments;private FragmentPagerAdapter mAdapter;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_style2);initView();}private void initView() {// find viewmViewPager = findViewById(R.id.fragment_vp);mTabRadioGroup = findViewById(R.id.tabs_rg);// init fragmentmFragments = new ArrayList< (4);mFragments.add(BlankFragment.newInstance("今日"));mFragments.add(BlankFragment.newInstance("记录"));mFragments.add(BlankFragment.newInstance("通讯录"));mFragments.add(BlankFragment.newInstance("设置"));// init view pagermAdapter = new MyFragmentPagerAdapter(getSupportFragmentManager(), mFragments);mViewPager.setAdapter(mAdapter);// register listenermViewPager.addOnPageChangeListener(mPageChangeListener);mTabRadioGroup.setOnCheckedChangeListener(mOnCheckedChangeListener);}@Overrideprotected void onDestroy() {super.onDestroy();mViewPager.removeOnPageChangeListener(mPageChangeListener);}private ViewPager.OnPageChangeListener mPageChangeListener = new ViewPager.OnPageChangeListener() {@Overridepublic void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}@Overridepublic void onPageSelected(int position) {RadioButton radioButton = (RadioButton) mTabRadioGroup.getChildAt(position);radioButton.setChecked(true);}@Overridepublic void onPageScrollStateChanged(int state) {}};private RadioGroup.OnCheckedChangeListener mOnCheckedChangeListener = new RadioGroup.OnCheckedChangeListener() {@Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) {for (int i = 0; i < group.getChildCount(); i++) {if (group.getChildAt(i).getId() == checkedId) {mViewPager.setCurrentItem(i);return;}}}};private class MyFragmentPagerAdapter extends FragmentPagerAdapter {private List<Fragment  mList;public MyFragmentPagerAdapter(FragmentManager fm, List<Fragment  list) {super(fm);this.mList = list;}@Overridepublic Fragment getItem(int position) {return this.mList == null ? null : this.mList.get(position);}@Overridepublic int getCount() {return this.mList == null ? 0 : this.mList.size();}}}

这里唯一注意点的就是两个监听事件,要实现底部导航按钮和页面的联动。

四、带页面跳转功能的底部导航

很多 APP 的底部导航栏中间有一个很大的按钮,点击后通常是打开一个新的页面,这里我们要实现的就是这种底部导航。 依旧是使用 RadioGroup 来做,只不过中间一个 tab 我们先用一个空的 View 来占位,然后在这个 View 的位置放置一个较大的按钮来覆盖住。

1. 布局文件

<?xml version="1.0" encoding="utf-8"?
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".style3.Style3Activity" <FrameLayoutandroid:id="@+id/fragment_container"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_above="@+id/tabs_rg" / <RadioGroupandroid:id="@+id/tabs_rg"android:layout_width="match_parent"android:layout_height="56dp"android:layout_alignParentBottom="true"android:background="#dcdcdc"android:orientation="horizontal" <RadioButtonandroid:id="@+id/today_tab"style="@style/Custom.TabRadioButton"android:checked="true"android:drawableTop="@drawable/tab_sign_selector"android:text="今日" / <RadioButtonandroid:id="@+id/record_tab"style="@style/Custom.TabRadioButton"android:drawableTop="@drawable/tab_record_selector"android:text="记录" / <View style="@style/Custom.TabRadioButton" / <RadioButtonandroid:id="@+id/contact_tab"style="@style/Custom.TabRadioButton"android:drawableTop="@drawable/tab_contact_selector"android:text="通讯录" / <RadioButtonandroid:id="@+id/settings_tab"style="@style/Custom.TabRadioButton"android:drawableTop="@drawable/tab_setting_selector"android:text="设置" / </RadioGroup <ImageViewandroid:id="@+id/sign_iv"android:layout_width="80dp"android:layout_height="80dp"android:layout_alignParentBottom="true"android:layout_centerHorizontal="true"android:background="@android:color/transparent"android:src="@mipmap/sign" /
</RelativeLayout 

2. Activity 类

public class Style3Activity extends AppCompatActivity {private RadioGroup mTabRadioGroup;private SparseArray<Fragment  mFragmentSparseArray;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_style3);initView();}private void initView() {mTabRadioGroup = findViewById(R.id.tabs_rg);mFragmentSparseArray = new SparseArray< ();mFragmentSparseArray.append(R.id.today_tab, BlankFragment.newInstance("今日"));mFragmentSparseArray.append(R.id.record_tab, BlankFragment.newInstance("记录"));mFragmentSparseArray.append(R.id.contact_tab, BlankFragment.newInstance("通讯录"));mFragmentSparseArray.append(R.id.settings_tab, BlankFragment.newInstance("设置"));mTabRadioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {@Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) {// 具体的fragment切换逻辑可以根据应用调整,例如使用show()/hide()getSupportFragmentManager().beginTransaction().replace(R.id.fragment_container,mFragmentSparseArray.get(checkedId)).commit();}});// 默认显示第一个getSupportFragmentManager().beginTransaction().add(R.id.fragment_container,mFragmentSparseArray.get(R.id.today_tab)).commit();findViewById(R.id.sign_iv).setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {startActivity(new Intent(Style3Activity.this, SignActivity.class));}});}}

注意:

如果这里你也想使用 ViewPager 来展示 Fragment 的话,一定要注意这里的 RadioGroup 中间有一个占位的 View,即两者的监听事件里,实现联动时要考虑多个这个 View 的存在。更多教程请访问码农之家

代码地址: https://gitee.com/afei_/BottomTabbar

到此这篇关于Android底部导航栏的三种风格实现的文章就介绍到这了,更多相关Android底部导航栏内容请搜索ZaLou.Cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持ZaLou.Cn!

Android底部导航栏的三种风格实现相关推荐

  1. 转载:Android底部导航栏,三种风格和实现

    原文出处 标题:Android底部导航栏,三种风格和实现 作者:阿飞__ 原文链接:Android底部导航栏,三种风格和实现_阿飞__的博客-CSDN博客_android导航栏 一.效果图展示 如果动 ...

  2. Android底部导航栏,三种风格和实现

    一.效果图展示 如果动图没有动的话,也可以看下面这个静态图 以下挨个分析每个的实现,这里只做简单的效果展示,大家可以基于目前代码做二次开发. 二.BottomNavigationView 这是 Goo ...

  3. 21天学习之二(Android 10.0 SystemUI默认去掉底部导航栏的三种方法)

    活动地址:CSDN21天学习挑战赛 1.概述 在定制化开发中,在SystemUI的一些定制功能中,针对默认去掉底部导航栏的方法有好几种,StatusBar和DisplayPolicy.java中api ...

  4. Android底部导航栏的四种实现

    现在大多数App都会用到底部导航栏,比如常见的聊天工具QQ.微信,购物App等等,有了底部导航栏,用户可以随时切换界面,查看不同的内容.它的实现方式也很多,以前大多使用TabHost来实现,但是现在我 ...

  5. android底部导航栏软件,三步搞定android应用底部导航栏

    很多android应用底部都有一个底部导航栏,方便用户在使用过程中随意切换.目前常用的做法有三种:一种是使用自定义tabHost,一种是使用activityGroup,一种是结合FrameLayout ...

  6. Android底部导航栏最常用的两种写法

    先来看看底部导航栏的效果 Android 底部导航栏有很多种写法,例如: RadioGroup , Tablayout, TabHost  , LinearLayout + ImageView + T ...

  7. 底部导航栏的几种实现方式

    概述 Android底部导航栏实现方式真的是太多了~在这里仅介绍几种实现方式~建议使用TabLayout +ViewPager ,TabLayout是Android Material Design中的 ...

  8. Android底部导航栏切换页面填坑

    ** Android底部导航栏切换页面填坑 ** 这个效果的实现关键点就是给选项赋予两种状态,focused和normal,在主程序中用监听判断是否被选中,就给被选中的选项设focused为true, ...

  9. Android底部导航栏+消息提醒

    Android底部导航栏+消息提醒 最近想在网上找一些Android底部导航栏切换并能提供消息提醒的案例,虽然有很多案例但都不是我想要的.我就开始自己瞎研究了,废话不多说了,直接上代码. 1.先创建一 ...

最新文章

  1. 无法从“const char [10]”转换为“char *”
  2. sqlite 日期时间类型学习1
  3. 航飞原始影像外方位元素_【技术】无人机倾斜摄影建模技术在虚拟现实中的应用...
  4. java将030A转换为方块_JAVA试题
  5. linux-buff/cache过大导致内存不足-程序异常
  6. Android 监控网络状态
  7. 基于Matlab的人脸识别设计(PCA)
  8. 奥维地图从服务器获取信息超时,2021奥维地图不能用了原因及解决办法
  9. JAVA经纬度互转、计算工具类
  10. python多元逻辑回归_Python机器学习的练习四:多元逻辑回归
  11. android psensor测试,android传感器Gsensor和Psensor的使用举例
  12. vue js监听浏览器tab页切换
  13. JAVA线上故障排查招式
  14. 便签里的文件怎么分享?怎么把便签里的内容弄成文件发送
  15. 宝塔环境使用微软OneDrive云盘免费自动备份网站数据最佳方案!
  16. 将Excel表格转换为MarkDown表格
  17. 云主机和物理机的区别
  18. Lect2 线性分类
  19. Linux服务器:Linux中VMware虚拟机硬盘空间扩大方法
  20. BVR、RV、BV电线三者区别

热门文章

  1. 浅谈Flink对象重用(object reuse)
  2. php fpm设置时区,php设置时区的解决方案
  3. DEDECMS后台文章发布出错解决方案
  4. F. Equalize the Array(思维+前缀和)
  5. 今日头条还可以引流么?今日头条引流效果怎么样?
  6. 将.m3u8转换为视频文件保存到本地
  7. 旧貌换新颜 | 凯云科技整装待发,迎风飞扬
  8. 有时候可用 UIWebView 代替 UITextView,解决行间距问题
  9. 配音软件哪个好用?好用的配音软件有哪些?你不知道的3款配音软件
  10. 国内可用的 ChatGPT