रनटाइम के दौरान,
FragmentManager
उपयोगकर्ता के इंटरैक्शन की वजह से, फ़्रैगमेंट के साथ जोड़, हटा, बदल, और अन्य कार्रवाइयां कर सकता है. फ़्रैगमेंट में किए गए हर बदलाव के सेट को ट्रांज़ैक्शन कहा जाता है. साथ ही, FragmentTransaction
क्लास से मिले एपीआई का इस्तेमाल करके, यह तय किया जा सकता है कि ट्रांज़ैक्शन में क्या करना है. एक से ज़्यादा कार्रवाइयों को एक ही लेन-देन में ग्रुप किया जा सकता है. उदाहरण के लिए, एक लेन-देन में कई फ़्रैगमेंट जोड़े जा सकते हैं या बदले जा सकते हैं. एक ही स्क्रीन पर एक से ज़्यादा सिबलिंग फ़्रैगमेंट दिखने पर, यह ग्रुपिंग काम की हो सकती है. जैसे, स्प्लिट व्यू के साथ.
हर लेन-देन को FragmentManager
की ओर से मैनेज किए जाने वाले बैक स्टैक में सेव किया जा सकता है. इससे उपयोगकर्ता, फ़्रैगमेंट में हुए बदलावों के ज़रिए पीछे की ओर नेविगेट कर सकता है. यह सुविधा, गतिविधियों के ज़रिए पीछे की ओर नेविगेट करने की तरह ही है.
beginTransaction()
को कॉल करके, FragmentManager
से FragmentTransaction
का एक इंस्टेंस पाया जा सकता है, जैसा कि इस उदाहरण में दिखाया गया है:
Kotlin
val fragmentManager = ... val fragmentTransaction = fragmentManager.beginTransaction()
Java
FragmentManager fragmentManager = ... FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
हर FragmentTransaction
पर फ़ाइनल कॉल, लेन-देन को पक्का करना चाहिए.
commit()
, FragmentManager
को कॉल सिग्नल भेजता है कि सभी ऑपरेशन, लेन-देन में जोड़ दिए गए हैं.
Kotlin
val fragmentManager = ... // The fragment-ktx module provides a commit block that automatically // calls beginTransaction and commit for you. fragmentManager.commit { // Add operations here }
Java
FragmentManager fragmentManager = ... FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction(); // Add operations here fragmentTransaction.commit();
फ़्रैगमेंट की स्थिति में हुए बदलावों को फिर से क्रम में लगाने की अनुमति दें
हर FragmentTransaction
को setReorderingAllowed(true)
का इस्तेमाल करना चाहिए:
Kotlin
supportFragmentManager.commit { ... setReorderingAllowed(true) }
Java
FragmentManager fragmentManager = ... fragmentManager.beginTransaction() ... .setReorderingAllowed(true) .commit();
व्यवहार की कम्पैटिबिलिटी के लिए, रीऑर्डर करने का फ़्लैग डिफ़ॉल्ट रूप से चालू नहीं होता.
हालांकि, FragmentManager
को आपके FragmentTransaction
को सही तरीके से लागू करने की अनुमति देना ज़रूरी है. खास तौर पर, जब यह बैक स्टैक पर काम करता है और एनिमेशन और ट्रांज़िशन चलाता है. फ़्लैग चालू करने से यह पक्का होता है कि अगर एक साथ कई लेन-देन किए जाते हैं, तो बीच में जोड़े गए और तुरंत बदले गए किसी भी फ़्रैगमेंट के लाइफ़साइकल में बदलाव नहीं होता या उनके ऐनिमेशन या ट्रांज़िशन लागू नहीं होते. ध्यान दें कि इस फ़्लैग का असर, लेन-देन के शुरू में होने वाले प्रोसेस और popBackStack()
की मदद से लेन-देन को रिवर्स करने, दोनों पर पड़ता है.
फ़्रैगमेंट जोड़ना और हटाना
FragmentManager
में कोई फ़्रैगमेंट जोड़ने के लिए, लेन-देन पर add()
को कॉल करें. इस तरीके से, फ़्रैगमेंट के लिए कंटेनर का आईडी और उस फ़्रैगमेंट का क्लास नाम मिलता है जिसे जोड़ना है. जोड़ा गया फ़्रैगमेंट, RESUMED
स्टेटस पर ले जाया जाता है. हमारा सुझाव है कि कंटेनर, व्यू हैरारकी का हिस्सा हो और वह FragmentContainerView
हो.
होस्ट से किसी फ़्रैगमेंट को हटाने के लिए, remove()
को कॉल करें. साथ ही, findFragmentById()
या findFragmentByTag()
की मदद से फ़्रैगमेंट मैनेजर से वापस पाया गया फ़्रैगमेंट इंस्टेंस पास करें.
अगर फ़्रैगमेंट व्यू को पहले किसी कंटेनर में जोड़ा गया था, तो व्यू को कंटेनर से हटा दिया जाता है. हटाए गए फ़्रैगमेंट को
DESTROYED
स्थिति में ले जाया गया है.
किसी कंटेनर में मौजूद फ़्रैगमेंट को, आपके दिए गए किसी नए फ़्रैगमेंट क्लास के इंस्टेंस से बदलने के लिए, replace()
का इस्तेमाल करें. replace()
को कॉल करना, किसी कंटेनर में फ़्रैगमेंट के साथ remove()
को कॉल करने और उसी कंटेनर में नया फ़्रैगमेंट जोड़ने जैसा है.
नीचे दिया गया कोड स्निपेट आपको एक फ़्रैगमेंट को दूसरे फ़्रैगमेंट से बदलने का तरीका बताता है:
Kotlin
// Create new fragment val fragmentManager = // ... // Create and commit a new transaction fragmentManager.commit { setReorderingAllowed(true) // Replace whatever is in the fragment_container view with this fragment replace<ExampleFragment>(R.id.fragment_container) }
Java
// Create new fragment and transaction FragmentManager fragmentManager = ... FragmentTransaction transaction = fragmentManager.beginTransaction(); transaction.setReorderingAllowed(true); // Replace whatever is in the fragment_container view with this fragment transaction.replace(R.id.fragment_container, ExampleFragment.class, null); // Commit the transaction transaction.commit();
इस उदाहरण में, अगर कोई फ़्रैगमेंट फ़िलहाल R.id.fragment_container
से पहचाने गए लेआउट कंटेनर में मौजूद है, तो ExampleFragment
का एक नया इंस्टेंस इसे बदल देता है.
डिफ़ॉल्ट रूप से, FragmentTransaction
में किए गए बदलाव, पिछली गतिविधियों में नहीं जोड़े जाते. इन बदलावों को सेव करने के लिए, FragmentTransaction
पर addToBackStack()
को कॉल करें. ज़्यादा जानकारी के लिए, फ़्रैगमेंट मैनेजर देखें.
कमिट करना एसिंक्रोनस है
commit()
को कॉल करने पर, तुरंत लेन-देन नहीं होता. इसके बजाय, ट्रांज़ैक्शन को मुख्य यूज़र इंटरफ़ेस (यूआई) थ्रेड पर चलाने के लिए शेड्यूल किया जाता है. ऐसा करने के लिए ज़रूरी है. अगर ज़रूरी हो, तो अपने यूज़र इंटरफ़ेस (यूआई) थ्रेड पर फ़्रैगमेंट ट्रांज़ैक्शन को तुरंत चलाने के लिए, commitNow()
को कॉल करें.
ध्यान दें कि commitNow
को addToBackStack
के साथ इस्तेमाल नहीं किया जा सकता. इसके अलावा, executePendingTransactions()
को कॉल करके, commit()
कॉल की मदद से सबमिट किए गए उन सभी FragmentTransactions
को चलाया जा सकता है जो अब तक नहीं चले हैं. यह तरीका addToBackStack
के साथ काम करता है.
इस्तेमाल के ज़्यादातर उदाहरणों के लिए, commit()
का इस्तेमाल करना ही काफ़ी है.
ऑपरेशन का क्रम अहम है
FragmentTransaction
में कार्रवाइयों का क्रम बहुत अहम होता है. खास तौर पर, setCustomAnimations()
का इस्तेमाल करते समय. यह तरीका, दिए गए ऐनिमेशन को उसके बाद होने वाले सभी फ़्रैगमेंट ऑपरेशन पर लागू करता है.
Kotlin
supportFragmentManager.commit { setCustomAnimations(enter1, exit1, popEnter1, popExit1) add<ExampleFragment>(R.id.container) // gets the first animations setCustomAnimations(enter2, exit2, popEnter2, popExit2) add<ExampleFragment>(R.id.container) // gets the second animations }
Java
getSupportFragmentManager().beginTransaction() .setCustomAnimations(enter1, exit1, popEnter1, popExit1) .add(R.id.container, ExampleFragment.class, null) // gets the first animations .setCustomAnimations(enter2, exit2, popEnter2, popExit2) .add(R.id.container, ExampleFragment.class, null) // gets the second animations .commit()
फ़्रैगमेंट के लाइफ़साइकल को सीमित करना
FragmentTransactions
, ट्रांज़ैक्शन के स्कोप में जोड़े गए अलग-अलग फ़्रैगमेंट की लाइफ़साइकल की स्थिति पर असर डाल सकता है. FragmentTransaction
बनाते समय, setMaxLifecycle()
दिए गए फ़्रैगमेंट के लिए ज़्यादा से ज़्यादा स्थिति सेट करता है. उदाहरण के लिए, ViewPager2
, ऑफ़-स्क्रीन फ़्रैगमेंट को STARTED
स्टेटस तक सीमित करने के लिए, setMaxLifecycle()
का इस्तेमाल करता है.
फ़्रैगमेंट के व्यू दिखाना और छिपाना
कंटेनर में जोड़े गए फ़्रैगमेंट के व्यू को दिखाने और छिपाने के लिए, FragmentTransaction
तरीकोंshow()
और hide()
का इस्तेमाल करें.
ये तरीके, फ़्रैगमेंट के लाइफ़साइकल पर असर डाले बिना, फ़्रैगमेंट के व्यू की विज़िबिलिटी सेट करते हैं.
किसी फ़्रेगमेंट में व्यू की दिखने की स्थिति को टॉगल करने के लिए, फ़्रेगमेंट ट्रांज़ैक्शन का इस्तेमाल करना ज़रूरी नहीं है. हालांकि, ये तरीके उन मामलों में काम के होते हैं जहां आपको दिखने की स्थिति में किए गए बदलावों को बैक स्टैक पर मौजूद ट्रांज़ैक्शन से जोड़ना हो.
फ़्रैगमेंट को अटैच करना और अलग करना
FragmentTransaction
तरीका detach()
, यूज़र इंटरफ़ेस (यूआई) से फ़्रैगमेंट को अलग करता है और इसके व्यू हैरारकी को खत्म कर देता है. फ़्रैगमेंट उसी स्थिति (STOPPED
) में बना रहता है जिसमें उसे पिछली स्टैक पर रखा गया था.
इसका मतलब है कि फ़्रैगमेंट को यूज़र इंटरफ़ेस (यूआई) से हटा दिया गया है, लेकिन इसे अब भी फ़्रैगमेंट मैनेजर मैनेज करता है.
attach()
वाला तरीका, उस फ़्रैगमेंट को फिर से जोड़ता है जिससे इसे पहले हटाया गया था.
ऐसा करने पर, इसकी व्यू हैरारकी फिर से बनाई जाती है, यूज़र इंटरफ़ेस (यूआई) से अटैच की जाती है, और दिखाई जाती है.
FragmentTransaction
को कार्रवाइयों का सिंगल ऐटॉमिक सेट माना जाता है. इसलिए, एक ही ट्रांज़ैक्शन में, एक फ़्रैगमेंट इंस्टेंस पर detach
और attach
, दोनों को कॉल करने पर, एक-दूसरे को असरदार तरीके से रद्द कर दिया जाता है. इस तरह, फ़्रैगमेंट का यूज़र इंटरफ़ेस (यूआई) खत्म होने और तुरंत फिर से बनाने से बचा जा सकता है. अगर commit()
का इस्तेमाल करना है, तो executePendingOperations()
से अलग किए गए अलग-अलग ट्रांज़ैक्शन का इस्तेमाल करें. अगर आपको फ़्रैगमेंट को अलग करना है और तुरंत फिर से अटैच करना है, तो ट्रांज़ैक्शन का इस्तेमाल करें.