Dynamic Fragment is a type of fragment that is defined in an XML layout file and called using FragmentManager class. The FragmentManager class is responsible for managing fragments. It is a part of the Activity and its lifecycle depends on the lifecycle of its container activity. Dynamic Fragments are more responsive and flexible than Static Fragments.
Properties of Dynamic Fragment:
- Defined in Java class by extending FragmentManager class.
- Having a fixed position in the Activity’s layout but its content can be changed.
- Can be added, removed, or replaced at runtime.
- Created when the Activity is created and destroyed when the activity is destroyed.
Step by Step Implementation
Step 1: Create a New Project in Android Studio
To create a new project in Android Studio please refer to How to Create/Start a New Project in Android Studio. Note that select Java as the programming language.
Step 2: Working with the activity_main.xml file
Navigate to the app > res > layout > activity_main.xml and add the below code to that file. Below is the code for the activity_main.xml file. Comments are added inside the code to understand the code in more detail.
XML
| <?xmlversion="1.0"encoding="utf-8"?><LinearLayout   android:layout_width="match_parent"   android:layout_height="match_parent"   android:orientation="vertical"   tools:context=".MainActivity"> Â   <LinearLayout       android:layout_width="match_parent"       android:layout_height="wrap_content"       android:background="#BDBDBD"       android:padding="15dp"       android:weightSum="3"> Â       <Button           android:id="@+id/btnMessages"           android:layout_width="wrap_content"           android:layout_height="wrap_content"           android:layout_weight="1"           android:text="Messages"           android:layout_marginRight="5dp"/> Â       <Button           android:id="@+id/btnStatus"           android:layout_width="wrap_content"           android:layout_height="wrap_content"           android:layout_weight="1"           android:layout_marginRight="5dp"           android:text="Status"/> Â       <Button           android:id="@+id/btnCalls"           android:layout_width="wrap_content"           android:layout_height="wrap_content"           android:layout_weight="1"           android:text="Calls"/> Â   </LinearLayout> Â   <FrameLayout       android:id="@+id/FL"       android:layout_width="match_parent"       android:layout_height="match_parent"/> Â</LinearLayout> | 
Step 3: Working with Activity file (e.g. MainActivity.java)
Here we call fragments using FragmentManager class in Frame Layout.
Java
| packagecom.anas.dynamicfragment; Âimportandroidx.appcompat.app.AppCompatActivity;importandroidx.fragment.app.Fragment;importandroidx.fragment.app.FragmentManager;importandroidx.fragment.app.FragmentTransaction; Âimportandroid.annotation.SuppressLint;importandroid.os.Bundle;importandroid.util.Log;importandroid.view.View;importandroid.widget.Button;importandroid.widget.TextView; Â// contains dynamic frag + backstack// of frags + data passing in fragspublicclassMainActivity extendsAppCompatActivity { Â    String Root_Frag = "root_fagment";    @Override    protectedvoidonCreate(Bundle savedInstanceState)    {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main); Â        Button btnMessages, btnStatus, btnCalls; Â        btnMessages = findViewById(R.id.btnMessages);        btnStatus = findViewById(R.id.btnStatus);        btnCalls = findViewById(R.id.btnCalls); Â        // default frag        loadFrag(newMessagesFragment(), 0); Â        btnMessages.setOnClickListener(newView.OnClickListener() {            @Override            publicvoidonClick(View view)            { Â                loadFrag(newMessagesFragment(), 0);            }        }); Â        btnStatus.setOnClickListener(newView.OnClickListener() {            @Override            publicvoidonClick(View view)            { Â                loadFrag(newStatusFragment(), 1);            }        }); Â        btnCalls.setOnClickListener(newView.OnClickListener() {            @Override            publicvoidonClick(View view)            { Â                loadFrag(newCallsFragment(), 1);            }        });    } Â    // flag 0 for add, 1 for replace    publicvoidloadFrag(Fragment fragment_name, intflag)    {        FragmentManager fm = getSupportFragmentManager();        FragmentTransaction ft = fm.beginTransaction(); Â        if(flag == 0) {            ft.add(R.id.FL, fragment_name); Â            fm.popBackStack(Root_Frag, FragmentManager.POP_BACK_STACK_INCLUSIVE);            ft.addToBackStack(Root_Frag);        }        else{            ft.replace(R.id.FL, fragment_name);            ft.addToBackStack(null);        } Â        ft.commit();    }} | 
Step 4: Working with Fragment layout (e.g. fragment_messages.xml)
XML
| <?xmlversion="1.0"encoding="utf-8"?><LinearLayout   android:layout_width="match_parent"   android:layout_height="match_parent"   android:background="#f0f4c3"   android:gravity="center"   tools:context=".MessagesFragment"> Â   <TextView       android:id="@+id/txtMessagesFrag"       android:layout_width="wrap_content"       android:layout_height="wrap_content"       android:text="Messages Fragment"       android:textSize="22sp"       android:textColor="#cddc39"       android:textStyle="italic|bold"/> Â</LinearLayout> | 
Step 5: Working with Fragment layout (e.g. fragment_status.xml)
XML
| <?xmlversion="1.0"encoding="utf-8"?><LinearLayout   android:layout_width="match_parent"   android:layout_height="match_parent"   android:background="#b2ebf2"   android:gravity="center"   tools:context=".StatusFragment"> Â   <TextView       android:id="@+id/txtUpperFrag"       android:layout_width="wrap_content"       android:layout_height="wrap_content"       android:text="Status Fragment"       android:textSize="22sp"       android:textColor="#00bcd4"       android:textStyle="italic|bold"/> Â</LinearLayout> | 
Step 6: Working with Fragment layout (e.g. fragment_calls.xml)
XML
| <?xmlversion="1.0"encoding="utf-8"?><LinearLayout   android:layout_width="match_parent"   android:layout_height="match_parent"   android:background="#f8bbd0"   android:gravity="center"   tools:context=".CallsFragment"> Â   <TextView       android:id="@+id/txtUpperFrag"       android:layout_width="wrap_content"       android:layout_height="wrap_content"       android:text="Calls Fragment"       android:textSize="22sp"       android:textColor="#e91e63"       android:textStyle="italic|bold"/> Â</LinearLayout> | 
Step 7: Working with Fragment (e.g. MessagesFragment.java)
Java
| packagecom.anas.dynamicfragment; Âimportandroid.annotation.SuppressLint;importandroid.os.Bundle; Âimportandroidx.fragment.app.Fragment; Âimportandroid.util.Log;importandroid.view.LayoutInflater;importandroid.view.View;importandroid.view.ViewGroup;importandroid.widget.TextView; ÂpublicclassMessagesFragment extendsFragment { Â    publicMessagesFragment()    {        // Required empty public constructor    } Â    @SuppressLint("LongLogTag")    @Override    publicView onCreateView(LayoutInflater inflater, ViewGroup container,                             Bundle savedInstanceState)    { Â        View view = inflater.inflate(R.layout.fragment_messages, container, false);        returnview;    }} | 
Step 8: Working with Fragment (e.g. StatusFragment.java)
Java
| packagecom.anas.dynamicfragment; Âimportandroid.os.Bundle; Âimportandroidx.fragment.app.Fragment; Âimportandroid.view.LayoutInflater;importandroid.view.View;importandroid.view.ViewGroup; ÂpublicclassStatusFragment extendsFragment { Â    publicStatusFragment()    {        // Required empty public constructor    } Â    @Override    publicView onCreateView(LayoutInflater inflater, ViewGroup container,                             Bundle savedInstanceState)    {        // Inflate the layout for this fragment        View view = inflater.inflate(R.layout.fragment_status, container, false); Â        returnview;    }} | 
Step 9: Working with Fragment (e.g. CallsFragment.java)
Java
| packagecom.anas.dynamicfragment; Âimportandroid.os.Bundle; Âimportandroidx.fragment.app.Fragment; Âimportandroid.view.LayoutInflater;importandroid.view.View;importandroid.view.ViewGroup; ÂpublicclassCallsFragment extendsFragment { Â    publicCallsFragment()    {        // Required empty public constructor    } Â    @Override    publicView onCreateView(LayoutInflater inflater, ViewGroup container,                             Bundle savedInstanceState)    {        // Inflate the layout for this fragment        View view = inflater.inflate(R.layout.fragment_calls, container, false); Â        returnview;    }} | 
Output:
Click on the Messages Button to load Messages Fragment:
 
Messages Fragment
Click on Status Button to load Status Fragment:
 
Status Fragment
Click on the Calls Button to load Calls Fragment:
 
Calls Fragment

 
                                    







