Here, I am going to discuss how we can create a sliding layout in Android. All the Android Applications are using sliding tabs.
Here, I have an action bar with the left side. There is a back button and in the center, it's showing the application title. Below that, it's showing the tabs. Each tab has a scrolling facility, in order to change the content. We can do click operations to the tabs.
First, create your mail layout, as shown below:
- <LinearLayout  
-     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" android:paddingLeft="@dimen/activity_horizontal_margin"  
- android:paddingRight="@dimen/activity_horizontal_margin"  
- android:paddingTop="@dimen/activity_vertical_margin"  
- android:orientation="vertical"  
- android:paddingBottom="@dimen/activity_vertical_margin" tools:context=".MainActivity">  
-     <include  
- android:id="@+id/tool_bar"  
- layout="@layout/tool_bar"  
- android:layout_height="wrap_content"  
- android:layout_width="match_parent"  
- />  
-     <techniche.com.slidingtabs.helper.SlidingTabLayout  
- android:id="@+id/tabs"  
- android:layout_width="match_parent"  
- android:layout_height="wrap_content"  
- android:elevation="2dp"  
- android:background="@color/sub_title_bg"/>  
-     <android.support.v4.view.ViewPager  
- android:id="@+id/pager"  
- android:layout_height="match_parent"  
- android:layout_width="match_parent"  
- android:layout_weight="1"  
- ></android.support.v4.view.ViewPager>  
- </LinearLayout>  
 
Tool_bar.xml
- <?xml version="1.0" encoding="utf-8"?>  
- <android.support.v7.widget.Toolbar  
-     xmlns:app="http://schemas.android.com/apk/res-auto"  
- android:layout_height="wrap_content"  
- android:layout_width="match_parent"  
- android:elevation="0dp"  
- android:contentInsetLeft="5dp"  
- android:contentInsetStart="5dp"  
- app:contentInsetLeft="5dp"  
- app:contentInsetStart="5dp"  
- android:contentInsetRight="5dp"  
- android:contentInsetEnd="5dp"  
- app:contentInsetRight="5dp"  
- app:contentInsetEnd="5dp"  
-     xmlns:android="http://schemas.android.com/apk/res/android" >  
-     <RelativeLayout  
- android:layout_width="match_parent"  
- android:layout_height="wrap_content" >  
-         <TextView  
- android:id="@+id/menuLeft"  
- android:layout_width="wrap_content"  
- android:layout_height="wrap_content"  
- android:layout_alignParentLeft="true"  
- android:layout_centerHorizontal="true"  
- android:layout_centerVertical="true"  
- android:layout_alignParentStart="true"  
- android:textColor="@color/white"  
- android:clickable="true" />  
-         <TextView  
- android:id="@+id/toolbar_title"  
- android:layout_width="wrap_content"  
- android:layout_height="wrap_content"  
- android:layout_centerHorizontal="true"  
- android:layout_centerVertical="true"  
- android:text="@string/app_name"  
- android:textColor="@color/white"/>  
-     </RelativeLayout>  
- </android.support.v7.widget.Toolbar>  
 
Here, I have a custom class named SlidingLayout.java, which is the file that I am using in the main layout. One needs to add the following lines in the build.gradle file, as shown below:
compile 'com.android.support:support-v13:22.2.1'
compile 'com.android.support:appcompat-v7:23.0.1'
Now, we need to create a style for the Application bar, as shown below:
- <style name="HomeTheme" parent="Theme.AppCompat.Light.DarkActionBar">  
-       
-     <item name="colorPrimary">@color/colorPrimary</item>  
-     <item name="colorPrimaryDark">@color/colorPrimaryDark</item>  
-     <item name="colorAccent">@color/colorAccent</item>  
-     <item name="windowActionBar">false</item>  
-     <item name="windowNoTitle">true</item>  
- </style>  
 
Now, bind the controls in the Java file, as given below:
- TextView backButton = (TextView) findViewById(R.id.menuLeft);  
- TextView titleText = (TextView) findViewById(R.id.toolbar_title);  
- backButton.setOnClickListener(new View.OnClickListener()  
- {  
-     @Override  
-     public void onClick(View view)  
-     {  
-         final FragmentManager fragmentManager = getFragmentManager();  
-         if (fragmentManager.getBackStackEntryCount() != 0)  
-         {  
-             fragmentManager.popBackStackImmediate();  
-         } else  
-             finish();  
-     }  
- });  
-   
- toolbar = (Toolbar) findViewById(R.id.tool_bar);  
- setSupportActionBar(toolbar);  
- adapter = new HomeViewPagerAdapter(getSupportFragmentManager(), Titles, Numboftabs);  
- pager = (ViewPager) findViewById(R.id.pager);  
- pager.setAdapter(adapter);  
-   
- tabs = (SlidingTabLayout) findViewById(R.id.tabs);  
- tabs.setDistributeEvenly(true);   
 
Now, we need to create the adapter for all the contents, as given below:
- public class HomeViewPagerAdapter extends FragmentStatePagerAdapter  
- {  
-     CharSequence Titles[];   
-     int NumbOfTabs;   
-       
-     public HomeViewPagerAdapter(FragmentManager fm, CharSequence mTitles[], int mNumbOfTabsumb)  
-         {  
-             super(fm);  
-             this.Titles = mTitles;  
-             this.NumbOfTabs = mNumbOfTabsumb;  
-         }  
-           
-     @Override  
-     public Fragment getItem(int position)  
-     {  
-             if (position == 0)   
-             {  
-                 FragmentOne healthFragment = new FragmentOne();  
-                 return healthFragment;  
-             } else if (position == 1)   
-             {  
-                 FragmentTwo appointmentFragment = new FragmentTwo();  
-                 return appointmentFragment;  
-             } else if (position == 2)   
-             {  
-                 FragmentThree favourateFragment = new FragmentThree();  
-                 return favourateFragment;  
-             } else   
-             {  
-                 FragmentFour messagesFragment = new FragmentFour();  
-                 return messagesFragment;  
-             }  
-         }  
-           
-     @Override  
-     public CharSequence getPageTitle(int position)  
-         {  
-             return Titles[position];  
-         }  
-           
-     @Override  
-     public int getCount()  
-     {  
-         return NumbOfTabs;  
-     }  
 
Now, create four fragments to show on selecting each tab, as shown below:
- <?xml version="1.0" encoding="utf-8"?>  
- <LinearLayout  
-     xmlns:android="http://schemas.android.com/apk/res/android"  
- android:orientation="vertical" android:layout_width="match_parent"  
- android:layout_height="match_parent">  
-     <TextView  
- android:layout_width="wrap_content"  
- android:text="Fragment Two"  
- android:layout_height="wrap_content" />  
- </LinearLayout>  
 
See the screenshots also,
 ![]() 
   ![]()