belongs to Maven artifact com.android.support:support-fragment:28.0.0-alpha1
FragmentManager
  public
  
  
  abstract
  class
  FragmentManager
  
    extends Object
  
  
  
  
  
  
| java.lang.Object | |
| ↳ | android.support.v4.app.FragmentManager | 
Static library support version of the framework's FragmentManager.
 Used to write apps that run on platforms prior to Android 3.0.  When running
 on Android 3.0 or above, this implementation is still used; it does not try
 to switch to the framework's implementation.  See the framework FragmentManager
 documentation for a class overview.
 
Your activity must derive from FragmentActivity to use this. From such an activity,
 you can acquire the FragmentManager by calling
 getSupportFragmentManager().
Summary
| Nested classes | |
|---|---|
| 
        
        
        
        
        interface | FragmentManager.BackStackEntryRepresentation of an entry on the fragment back stack, as created
 with  | 
| 
        
        
        
        
        class | FragmentManager.FragmentLifecycleCallbacksCallback interface for listening to fragment state changes that happen within a given FragmentManager. | 
| 
        
        
        
        
        interface | FragmentManager.OnBackStackChangedListenerInterface to watch for changes to the back stack. | 
| Constants | |
|---|---|
| int | POP_BACK_STACK_INCLUSIVEFlag for  | 
| Public constructors | |
|---|---|
| 
      FragmentManager()
       | |
| Public methods | |
|---|---|
| 
        abstract
        
        
        
        
        void | 
      addOnBackStackChangedListener(FragmentManager.OnBackStackChangedListener listener)
      Add a new listener for changes to the fragment back stack. | 
| 
        abstract
        
        
        
        
        FragmentTransaction | 
      beginTransaction()
      Start a series of edit operations on the Fragments associated with this FragmentManager. | 
| 
        abstract
        
        
        
        
        void | 
      dump(String prefix, FileDescriptor fd, PrintWriter writer, String[] args)
      Print the FragmentManager's state into the given stream. | 
| 
        
        
        static
        
        
        void | 
      enableDebugLogging(boolean enabled)
      Control whether the framework's internal fragment manager debugging logs are turned on. | 
| 
        abstract
        
        
        
        
        boolean | 
      executePendingTransactions()
      After a  | 
| 
        abstract
        
        
        
        
        Fragment | 
      findFragmentById(int id)
      Finds a fragment that was identified by the given id either when inflated from XML or as the container ID when added in a transaction. | 
| 
        abstract
        
        
        
        
        Fragment | 
      findFragmentByTag(String tag)
      Finds a fragment that was identified by the given tag either when inflated from XML or as supplied when added in a transaction. | 
| 
        abstract
        
        
        
        
        FragmentManager.BackStackEntry | 
      getBackStackEntryAt(int index)
      Return the BackStackEntry at index index in the back stack; entries start index 0 being the bottom of the stack. | 
| 
        abstract
        
        
        
        
        int | 
      getBackStackEntryCount()
      Return the number of entries currently in the back stack. | 
| 
        abstract
        
        
        
        
        Fragment | 
      getFragment(Bundle bundle, String key)
      Retrieve the current Fragment instance for a reference previously
 placed with  | 
| 
        abstract
        
        
        
        
        List<Fragment> | 
      getFragments()
      Get a list of all fragments that are currently added to the FragmentManager. | 
| 
        abstract
        
        
        
        
        Fragment | 
      getPrimaryNavigationFragment()
      Return the currently active primary navigation fragment for this FragmentManager. | 
| 
        abstract
        
        
        
        
        boolean | 
      isDestroyed()
      Returns true if the final  | 
| 
        abstract
        
        
        
        
        boolean | 
      isStateSaved()
      Returns  | 
| 
        abstract
        
        
        
        
        void | 
      popBackStack()
      Pop the top state off the back stack. | 
| 
        abstract
        
        
        
        
        void | 
      popBackStack(int id, int flags)
      Pop all back stack states up to the one with the given identifier. | 
| 
        abstract
        
        
        
        
        void | 
      popBackStack(String name, int flags)
      Pop the last fragment transition from the manager's fragment back stack. | 
| 
        abstract
        
        
        
        
        boolean | 
      popBackStackImmediate()
      Like  | 
| 
        abstract
        
        
        
        
        boolean | 
      popBackStackImmediate(int id, int flags)
      Like  | 
| 
        abstract
        
        
        
        
        boolean | 
      popBackStackImmediate(String name, int flags)
      Like  | 
| 
        abstract
        
        
        
        
        void | 
      putFragment(Bundle bundle, String key, Fragment fragment)
      Put a reference to a fragment in a Bundle. | 
| 
        abstract
        
        
        
        
        void | 
      registerFragmentLifecycleCallbacks(FragmentManager.FragmentLifecycleCallbacks cb, boolean recursive)
      Registers a  | 
| 
        abstract
        
        
        
        
        void | 
      removeOnBackStackChangedListener(FragmentManager.OnBackStackChangedListener listener)
      Remove a listener that was previously added with
  | 
| 
        abstract
        
        
        
        
        Fragment.SavedState | 
      saveFragmentInstanceState(Fragment f)
      Save the current instance state of the given Fragment. | 
| 
        abstract
        
        
        
        
        void | 
      unregisterFragmentLifecycleCallbacks(FragmentManager.FragmentLifecycleCallbacks cb)
      Unregisters a previously registered  | 
| Inherited methods | |
|---|---|
|  From
class 
  
    java.lang.Object
  
 | |
Constants
POP_BACK_STACK_INCLUSIVE
int POP_BACK_STACK_INCLUSIVE
Flag for popBackStack(String, int)
 and popBackStack(int, int): If set, and the name or ID of
 a back stack entry has been supplied, then all matching entries will
 be consumed until one that doesn't match is found or the bottom of
 the stack is reached.  Otherwise, all entries up to but not including that entry
 will be removed.
Constant Value: 1 (0x00000001)
Public constructors
Public methods
addOnBackStackChangedListener
void addOnBackStackChangedListener (FragmentManager.OnBackStackChangedListener listener)
Add a new listener for changes to the fragment back stack.
| Parameters | |
|---|---|
| listener | FragmentManager.OnBackStackChangedListener | 
beginTransaction
FragmentTransaction beginTransaction ()
Start a series of edit operations on the Fragments associated with this FragmentManager.
Note: A fragment transaction can only be created/committed prior
 to an activity saving its state.  If you try to commit a transaction
 after FragmentActivity.onSaveInstanceState()
 (and prior to a following FragmentActivity.onStart
 or FragmentActivity.onResume(), you will get an error.
 This is because the framework takes care of saving your current fragments
 in the state, and if changes are made after the state is saved then they
 will be lost.
| Returns | |
|---|---|
| FragmentTransaction | |
dump
void dump (String prefix, 
                FileDescriptor fd, 
                PrintWriter writer, 
                String[] args)Print the FragmentManager's state into the given stream.
| Parameters | |
|---|---|
| prefix | String: Text to print at the front of each line. | 
| fd | FileDescriptor: The raw file descriptor that the dump is being sent to. | 
| writer | PrintWriter: A PrintWriter to which the dump is to be set. | 
| args | String: Additional arguments to the dump request. | 
enableDebugLogging
void enableDebugLogging (boolean enabled)
Control whether the framework's internal fragment manager debugging logs are turned on. If enabled, you will see output in logcat as the framework performs fragment operations.
| Parameters | |
|---|---|
| enabled | boolean | 
executePendingTransactions
boolean executePendingTransactions ()
After a FragmentTransaction is committed with
 FragmentTransaction.commit(), it
 is scheduled to be executed asynchronously on the process's main thread.
 If you want to immediately executing any such pending operations, you
 can call this function (only from the main thread) to do so.  Note that
 all callbacks and other related behavior will be done from within this
 call, so be careful about where this is called from.
 
If you are committing a single transaction that does not modify the
 fragment back stack, strongly consider using
 commitNow() instead. This can help avoid
 unwanted side effects when other code in your app has pending committed
 transactions that expect different timing.
 This also forces the start of any postponed Transactions where
 postponeEnterTransition() has been called.
| Returns | |
|---|---|
| boolean | Returns true if there were any pending transactions to be executed. | 
findFragmentById
Fragment findFragmentById (int id)
Finds a fragment that was identified by the given id either when inflated from XML or as the container ID when added in a transaction. This first searches through fragments that are currently added to the manager's activity; if no such fragment is found, then all fragments currently on the back stack associated with this ID are searched.
| Parameters | |
|---|---|
| id | int | 
| Returns | |
|---|---|
| Fragment | The fragment if found or null otherwise. | 
findFragmentByTag
Fragment findFragmentByTag (String tag)
Finds a fragment that was identified by the given tag either when inflated from XML or as supplied when added in a transaction. This first searches through fragments that are currently added to the manager's activity; if no such fragment is found, then all fragments currently on the back stack are searched.
| Parameters | |
|---|---|
| tag | String | 
| Returns | |
|---|---|
| Fragment | The fragment if found or null otherwise. | 
getBackStackEntryAt
FragmentManager.BackStackEntry getBackStackEntryAt (int index)
Return the BackStackEntry at index index in the back stack; entries start index 0 being the bottom of the stack.
| Parameters | |
|---|---|
| index | int | 
| Returns | |
|---|---|
| FragmentManager.BackStackEntry | |
getBackStackEntryCount
int getBackStackEntryCount ()
Return the number of entries currently in the back stack.
| Returns | |
|---|---|
| int | |
getFragment
Fragment getFragment (Bundle bundle, String key)
Retrieve the current Fragment instance for a reference previously
 placed with putFragment(Bundle, String, Fragment).
| Parameters | |
|---|---|
| bundle | Bundle: The bundle from which to retrieve the fragment reference. | 
| key | String: The name of the entry in the bundle. | 
| Returns | |
|---|---|
| Fragment | Returns the current Fragment instance that is associated with the given reference. | 
getFragments
List<Fragment> getFragments ()
Get a list of all fragments that are currently added to the FragmentManager. This may include those that are hidden as well as those that are shown. This will not include any fragments only in the back stack, or fragments that are detached or removed.
The order of the fragments in the list is the order in which they were added or attached.
| Returns | |
|---|---|
| List<Fragment> | A list of all fragments that are added to the FragmentManager. | 
getPrimaryNavigationFragment
Fragment getPrimaryNavigationFragment ()
Return the currently active primary navigation fragment for this FragmentManager.
 The primary navigation fragment is set by fragment transactions using
 setPrimaryNavigationFragment(Fragment).
 
The primary navigation fragment's
 child FragmentManager will be called first
 to process delegated navigation actions such as popBackStack() if no ID
 or transaction name is provided to pop to.
| Returns | |
|---|---|
| Fragment | the fragment designated as the primary navigation fragment | 
isDestroyed
boolean isDestroyed ()
Returns true if the final Activity.onDestroy()
 call has been made on the FragmentManager's Activity, so this instance is now dead.
| Returns | |
|---|---|
| boolean | |
isStateSaved
boolean isStateSaved ()
Returns true if the FragmentManager's state has already been saved
 by its host. Any operations that would change saved state should not be performed
 if this method returns true. For example, any popBackStack() method, such as
 popBackStackImmediate() or any FragmentTransaction using
 commit() instead of
 commitAllowingStateLoss() will change
 the state and will result in an error.
| Returns | |
|---|---|
| boolean | true if this FragmentManager's state has already been saved by its host | 
popBackStack
void popBackStack ()
Pop the top state off the back stack. Returns true if there was one to pop, else false. This function is asynchronous -- it enqueues the request to pop, but the action will not be performed until the application returns to its event loop.
popBackStack
void popBackStack (int id, 
                int flags)Pop all back stack states up to the one with the given identifier. This function is asynchronous -- it enqueues the request to pop, but the action will not be performed until the application returns to its event loop.
| Parameters | |
|---|---|
| id | int: Identifier of the stated to be popped. If no identifier exists,
 false is returned.
 The identifier is the number returned byFragmentTransaction.commit().  ThePOP_BACK_STACK_INCLUSIVEflag can be used to control whether
 the named state itself is popped. | 
| flags | int: Either 0 orPOP_BACK_STACK_INCLUSIVE. | 
popBackStack
void popBackStack (String name, 
                int flags)Pop the last fragment transition from the manager's fragment back stack. If there is nothing to pop, false is returned. This function is asynchronous -- it enqueues the request to pop, but the action will not be performed until the application returns to its event loop.
| Parameters | |
|---|---|
| name | String: If non-null, this is the name of a previous back state
 to look for; if found, all states up to that state will be popped.  ThePOP_BACK_STACK_INCLUSIVEflag can be used to control whether
 the named state itself is popped. If null, only the top state is popped. | 
| flags | int: Either 0 orPOP_BACK_STACK_INCLUSIVE. | 
popBackStackImmediate
boolean popBackStackImmediate ()
Like popBackStack(), but performs the operation immediately
 inside of the call.  This is like calling executePendingTransactions()
 afterwards without forcing the start of postponed Transactions.
| Returns | |
|---|---|
| boolean | Returns true if there was something popped, else false. | 
popBackStackImmediate
boolean popBackStackImmediate (int id, 
                int flags)Like popBackStack(int, int), but performs the operation immediately
 inside of the call.  This is like calling executePendingTransactions()
 afterwards without forcing the start of postponed Transactions.
| Parameters | |
|---|---|
| id | int | 
| flags | int | 
| Returns | |
|---|---|
| boolean | Returns true if there was something popped, else false. | 
popBackStackImmediate
boolean popBackStackImmediate (String name, 
                int flags)Like popBackStack(String, int), but performs the operation immediately
 inside of the call.  This is like calling executePendingTransactions()
 afterwards without forcing the start of postponed Transactions.
| Parameters | |
|---|---|
| name | String | 
| flags | int | 
| Returns | |
|---|---|
| boolean | Returns true if there was something popped, else false. | 
putFragment
void putFragment (Bundle bundle, String key, Fragment fragment)
Put a reference to a fragment in a Bundle.  This Bundle can be
 persisted as saved state, and when later restoring
 getFragment(Bundle, String) will return the current
 instance of the same fragment.
| Parameters | |
|---|---|
| bundle | Bundle: The bundle in which to put the fragment reference. | 
| key | String: The name of the entry in the bundle. | 
| fragment | Fragment: The Fragment whose reference is to be stored. | 
registerFragmentLifecycleCallbacks
void registerFragmentLifecycleCallbacks (FragmentManager.FragmentLifecycleCallbacks cb, boolean recursive)
Registers a FragmentManager.FragmentLifecycleCallbacks to listen to fragment lifecycle events
 happening in this FragmentManager. All registered callbacks will be automatically
 unregistered when this FragmentManager is destroyed.
| Parameters | |
|---|---|
| cb | FragmentManager.FragmentLifecycleCallbacks: Callbacks to register | 
| recursive | boolean: true to automatically register this callback for all child FragmentManagers | 
removeOnBackStackChangedListener
void removeOnBackStackChangedListener (FragmentManager.OnBackStackChangedListener listener)
Remove a listener that was previously added with
 addOnBackStackChangedListener(OnBackStackChangedListener).
| Parameters | |
|---|---|
| listener | FragmentManager.OnBackStackChangedListener | 
saveFragmentInstanceState
Fragment.SavedState saveFragmentInstanceState (Fragment f)
Save the current instance state of the given Fragment. This can be used later when creating a new instance of the Fragment and adding it to the fragment manager, to have it create itself to match the current state returned here. Note that there are limits on how this can be used:
- The Fragment must currently be attached to the FragmentManager.
- A new Fragment created using this saved state must be the same class type as the Fragment it was created from.
- The saved state can not contain dependencies on other fragments --
 that is it can't use putFragment(Bundle, String, Fragment)to store a fragment reference because that reference may not be valid when this saved state is later used. Likewise the Fragment's target and result code are not included in this state.
| Parameters | |
|---|---|
| f | Fragment: The Fragment whose state is to be saved. | 
| Returns | |
|---|---|
| Fragment.SavedState | The generated state. This will be null if there was no interesting state created by the fragment. | 
unregisterFragmentLifecycleCallbacks
void unregisterFragmentLifecycleCallbacks (FragmentManager.FragmentLifecycleCallbacks cb)
Unregisters a previously registered FragmentManager.FragmentLifecycleCallbacks. If the callback
 was not previously registered this call has no effect. All registered callbacks will be
 automatically unregistered when this FragmentManager is destroyed.
| Parameters | |
|---|---|
| cb | FragmentManager.FragmentLifecycleCallbacks: Callbacks to unregister | 
- Annotations
- Interfaces- ActionBarDrawerToggle.Delegate
- ActionBarDrawerToggle.DelegateProvider
- ActivityCompat.OnRequestPermissionsResultCallback
- ActivityCompat.PermissionCompatDelegate
- FragmentManager.BackStackEntry
- FragmentManager.OnBackStackChangedListener
- LoaderManager.LoaderCallbacks
- NotificationCompat.Action.Extender
- NotificationCompat.Extender
- SharedElementCallback.OnSharedElementsReadyListener
- TaskStackBuilder.SupportParentable
 
- Classes- ActionBarDrawerToggle
- ActivityCompat
- ActivityManagerCompat
- ActivityOptionsCompat
- AlarmManagerCompat
- AppLaunchChecker
- AppOpsManagerCompat
- BundleCompat
- DialogFragment
- Fragment
- Fragment.SavedState
- FragmentActivity
- FragmentContainer
- FragmentController
- FragmentHostCallback
- FragmentManager
- FragmentManager.FragmentLifecycleCallbacks
- FragmentManagerNonConfig
- FragmentPagerAdapter
- FragmentStatePagerAdapter
- FragmentTabHost
- FragmentTransaction
- FrameMetricsAggregator
- JobIntentService
- ListFragment
- LoaderManager
- NavUtils
- NotificationCompat
- NotificationCompat.Action
- NotificationCompat.Action.Builder
- NotificationCompat.Action.WearableExtender
- NotificationCompat.BigPictureStyle
- NotificationCompat.BigTextStyle
- NotificationCompat.Builder
- NotificationCompat.CarExtender
- NotificationCompat.CarExtender.UnreadConversation
- NotificationCompat.CarExtender.UnreadConversation.Builder
- NotificationCompat.DecoratedCustomViewStyle
- NotificationCompat.InboxStyle
- NotificationCompat.MessagingStyle
- NotificationCompat.MessagingStyle.Message
- NotificationCompat.Style
- NotificationCompat.WearableExtender
- NotificationCompatExtras
- NotificationCompatSideChannelService
- NotificationManagerCompat
- RemoteInput
- RemoteInput.Builder
- ServiceCompat
- ShareCompat
- ShareCompat.IntentBuilder
- ShareCompat.IntentReader
- SharedElementCallback
- TaskStackBuilder
 
- Exceptions
Content and code samples on this page are subject to the licenses described in the Content License. Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Last updated 2025-02-10 UTC.
