In this part of tutorial, we will see how to make Navigation Bottom bar on Android using XAML .
Creating project.
Let’s create a new project called Bottom Bar.
data:image/s3,"s3://crabby-images/f867d/f867dfd29c3133c7e4e09d5e988b642dcbf5cc15" alt="Android Bottom bar"
Under the views folder, create 2 new ContentPage item called FirstPage and SecondPage.
data:image/s3,"s3://crabby-images/cf669/cf669e9b27e229cb7a5ccf10f5bc27f157f5fdbf" alt=""
In the MainPage.xaml, we need to change the page type from ContentPage to TabbedPage
<?xml version="1.0" encoding="utf-8" ?>
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
x:Class="BottomBar.Views.MainPage"
Title="{Binding Title}">
</TabbedPage>
And change the parent class from ContentPage to TabbedPage in MainPage.cs
public partial class MainPage : TabbedPage
{
public MainPage()
{
InitializeComponent();
}
}
Now, we define the TabbedPage content, by adding the two pages added previously:
<?xml version="1.0" encoding="utf-8" ?>
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:Views="clr-namespace:BottomBar.Views"
x:Class="BottomBar.Views.MainPage"
Title="{Binding Title}">
<NavigationPage Title="First">
<x:Arguments>
<Views:FirstPage />
</x:Arguments>
</NavigationPage>
<NavigationPage Title="Second">
<x:Arguments>
<Views:SecondPage />
</x:Arguments>
</NavigationPage>
</TabbedPage>
When you run the project, you will have the navigation bar in the top.
data:image/s3,"s3://crabby-images/e99ca/e99ca28ca902317e508ce4a04434764e4228ead0" alt=""
So we need only to define the position on the Bottom by adding this code :
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:Views="clr-namespace:BottomBar.Views"
xmlns:android="clr-namespace:Xamarin.Forms.PlatformConfiguration.AndroidSpecific;assembly=Xamarin.Forms.Core"
android:TabbedPage.ToolbarPlacement="Bottom"
x:Class="BottomBar.Views.MainPage"
Title="{Binding Title}">
Run the project and you will see that the navigation bar is in the bottom:
data:image/s3,"s3://crabby-images/9dd1b/9dd1ba99c736a76eb1a60b0a99b47d3d135457a7" alt=""
Let’s add some icons for each page title. First of all, you need to create new folder called drawable under Resources folder in Android project and put the icon images:
data:image/s3,"s3://crabby-images/46a77/46a77edcbeaf6c476640f8d59105deb102bdb1c3" alt=""
Finally, add icons in XAML for each page like this code:
<?xml version="1.0" encoding="utf-8" ?>
<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:Views="clr-namespace:BottomBar.Views"
xmlns:android="clr-namespace:Xamarin.Forms.PlatformConfiguration.AndroidSpecific;assembly=Xamarin.Forms.Core"
android:TabbedPage.ToolbarPlacement="Bottom"
x:Class="BottomBar.Views.MainPage"
Title="{Binding Title}">
<NavigationPage Title="First"
Icon="firstIcon.png">
<x:Arguments>
<Views:FirstPage />
</x:Arguments>
</NavigationPage>
<NavigationPage Title="Second"
Icon="secondIcon.png">
<x:Arguments>
<Views:SecondPage />
</x:Arguments>
</NavigationPage>
</TabbedPage>
Ass you can see, here, we have a bottom navigation bar with icons:
data:image/s3,"s3://crabby-images/f3640/f364071d69470e3c458ad97d2a448282b4e9111b" alt=""
Follow Me For Updates
Subscribe to my YouTube channel or follow me on Twitter or GitHub to be notified when I post new content.