arrow left
Back to Developer Education

Adding a Floating Action Button to Bottom Navigation Bar in Android

Adding a Floating Action Button to Bottom Navigation Bar in Android

Triggering actions is a critical factor to consider while designing an Android app. In most cases, buttons help to fulfill this purpose. <!--more--> Buttons such as compoundButton, ToggleButton, and RadioButton are commonly used in an Android application.

In this tutorial, we'll discuss the floating action button which is denoted by FAB.

Floating action buttons are unique from other user interface elements. They are circular with centralized icons that appear on top of other screen content. These buttons encourage users to take a range of actions, such as adding an item to a to-do list.

The common types of floating action buttons are:

  • Regular FAB- This type of floating action button does not have any extensions and is of standard size.
  • Mini FAB - This form of FAB is used on small screens.
  • Extended FABs - This type of button is larger and has text labels embedded into it.

Prerequisites

To follow along with this tutorial, you need:

  • Some basic understanding of the Kotlin programming language.
  • Basic knowledge of the fundamentals of Android development.

Goal

At the end of this tutorial, the reader will understand how to use material design components, how to create a bottom navigation bar, and how to add a floating action button.

Our final UI should look as follows:

UI

Step 1 - Creating a new project

To create a new project in Android Studio, go to File > New > New Project > Empty Activity, as shown below:

Creating a project

Give the project a descriptive name, such as FloatingActionButton, and then select Kotlin as your preferred programming language. Finally, click Finish to complete the project.

Step 2 - Adding Material design dependencies

To add Material design dependencies, navigate to the app level build.Gradle file. Under plugins, add id 'kotlin-android-extensions, then under dependencies, add the material design dependencies as shown below, and then click on Sync:

implementation 'com.google.android.material:material:1.3.0-alpha03' 

Step 3 - Creating a menu for the BottomNavigationView

To create an Android Resource file, navigate to the res directory and create a new Android Resource file.

Choose menu as your preferred Resource Type and give a descriptive file name such as bottom_menu_nav, then click Ok. Use the following code to assemble your menu:

<?xml version="1.0" encoding="utf-8"?>  
<menu xmlns:android="http://schemas.android.com/apk/res/android">  

      <item android:id="@+id/bnbMenuHome"  
      android:title="Home Icon"  
      android:icon="@drawable/ic_home_bnb"/>  
      
      <item android:id="@+id/bnbMenuSearch"  
      android:title="Search Icon"  
      android:icon="@drawable/ic_search_bnb"/>  
      
      <item android:id="@+id/bnbMenuPerson"  
      android:title="Profile Icon"  
      android:icon="@drawable/ic_person_bnb"/>  
      
      <item android:id="@+id/bnbMenuSetting"  
      android:title="Setting Icon"  
      android:icon="@drawable/ic_settings_bnb"/>  
  
</menu>

Step 4 - Importing icons

Let's add some icons to our BottomNavigationView. We will use five icons, four for our BottomNavigationView, and one for our floating action button.

To achieve this, navigate to the res directory, right-click on drawable, then choose New > Vector Asset from the menu:

Icons

Proceed to the clip art icon and then click it. Search for a home icon, then choose it and change the name to ic_home_bnb. Finally, click Next and Finish to complete the process.

Follow the same procedure and add the remaining search, person, setting, and add icons.

Note: you can add icons that best fit your needs.

Step 5 - Designing the user interface with FAB

The user interface allows users to interact with the app. It is vital to have an appealing UI design. In our case, the application interface should look as follows:

UI

The floating action button's background should contrast with the application's color scheme. We can do this by customizing the button's color using the color accent attribute.

Note: a BottomNavigationBar can contain a single task or component. However, it's advisable to include at least three destination icons.

Step 6 - Applying the required theme

We use Theme components to change the appearance of our application. Inside the res directory, navigate to the values folder then to the theme/style.xml file.

Change the parent theme from Theme.MaterialComponents.DayNight.DarkActionBar to Theme.MaterialComponents.

We also need to remove the shadow applied to the BottomNavigationBar by adding the following code in the MainActivity.kt file:

bottomNavView.background = null

Step 7 - MainActivity.kt class

The following bottom navigation code and floating button implementation should be included in the MainActivity.kt file, as illustrated below:

class MainActivity : AppCompatActivity() {   
    //declare a variable  
  private lateinit var floatingActionButton: FloatingActionButton  
  
    override fun onCreate(savedInstanceState: Bundle?) {  
      super.onCreate(savedInstanceState)  
      setContentView(R.layout.activity_main)  
  
      bottomNavView.background = null  //Removing the background shadow
      bottomNavView.menu.getItem(2).isEnabled = false  
  
      //creating a toast  
      floatingActionButton = findViewById(R.id.fab)  
      floatingActionButton.setOnClickListener { 
         //showing a toast message when clicked 
         Toast.makeText(this, "FloatingActionButton Clicked", Toast.LENGTH_SHORT).show()  
      }  
  }  
}

Conclusion

In this tutorial. we have discussed the different types of floating action buttons in Android.

We also learned how to create a bottom navigation bar and incorporate a floating action button into it.

You can find the full code here.

Further reading


Peer Review Contributions by: Wanja Mike

Published on: Jan 27, 2022
Updated on: Jul 15, 2024
CTA

Cloudzilla is FREE for React and Node.js projects

Deploy GitHub projects across every major cloud in under 3 minutes. No credit card required.
Get Started for Free