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

1. 设计底部导航栏页面

1.1. 创建必须的文件夹

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

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

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

1.2. 设计主页面

  • 首先设计子项: menu下新建nav_items.xml文件
<?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"> <item
android:id="@+id/nav_homes"
android:icon="@drawable/ic_home_black_24dp"
android:title="@string/nav_home" />
<item
android:id="@+id/nav_searchs"
android:icon="@drawable/ic_search_black_24dp"
android:title="@string/nav_search" />
<item
android:id="@+id/nav_accounts"
android:icon="@drawable/ic_account_circle_black_24dp"
android:title="@string/nav_account" />
</menu>
  • 设计个性化颜色,color文件夹下新建nav_item_color.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="@color/colorWhite" android:state_checked="true"/>
<item android:color="@color/colorWhiteTransparent" android:state_checked="false"/>
</selector>
  • 然后再主页面中引入子项 ,在activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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"
tools:context=".MainActivity"> <android.support.design.widget.BottomNavigationView
android:id="@+id/main_nav"
android:layout_width="match_parent"
android:layout_height="56dp"
android:layout_alignParentStart="true"
android:layout_alignParentLeft="true"
android:layout_alignParentBottom="true"
app:itemBackground="@color/colorPrimary"
app:itemIconTint="@color/nav_item_color"
app:itemTextColor="@color/nav_item_color"
app:menu="@menu/nav_items"></android.support.design.widget.BottomNavigationView> <FrameLayout
android:id="@+id/main_frame"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_above="@+id/main_nav"> </FrameLayout> </RelativeLayout>

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. 项目展示

最新文章

  1. jquery给div的innerHTML赋值
  2. 【使用Unity开发Windows Phone上的2D游戏】(1)千里之行始于足下
  3. [转]angularjs 设置全局变量的3种方法
  4. nrf51822裸机教程-硬件timer
  5. PHP5.3以上版本没有libmysql.dll,以及由此带来的困扰
  6. HTML中Meta属性http-equiv=&quot;X-UA-Compatible&quot;详解
  7. MapSearch 阅读随笔
  8. Come and join us at English corner
  9. [Codeforces Round #247 (Div. 2)] A. Black Square
  10. pure学习笔记
  11. python手记(46)
  12. Path.Combine 合并两个路径字符串,会出现的问题
  13. C# WinForm程序添加启动画面
  14. STS临时授权访问OSS
  15. 自学工业控制网络之路1.2-典型的现场总线介绍PROFIBUS
  16. Struct(二)
  17. angular的uiRouter服务学习(4)
  18. AOP:选择正确的时机进行编织
  19. 原生JavaScript实现的贪吃蛇
  20. HDUOJ----2952Counting Sheep

热门文章

  1. MaxScript 学习笔记【有转载】
  2. ELK 日志管理系统,再次尝试记录
  3. objective-C中的&quot;非正式协议&quot;和“正式协议”
  4. 强大的vim配置文件,让编程更随意 (转载)
  5. 使用批处理命令设置windows系统的ip地址和dns
  6. 相机IMU融合四部曲(一):D-LG-EKF详细解读
  7. 954I Yet Another String Matching Problem
  8. c语言条件编译#ifdef与#if defined
  9. js流程图:aworkflow.js
  10. PHP中文乱码解决办法[转]