1. परिचय
मटीरियल डिज़ाइन एक ऐसा सिस्टम है जो अच्छे और आकर्षक डिजिटल प्रॉडक्ट बनाता है. सिद्धांतों और कॉम्पोनेंट के एक जैसे सेट के तहत स्टाइल, ब्रैंडिंग, इंटरैक्शन, और मोशन की सुविधा इस्तेमाल करके, प्रॉडक्ट टीम अपने डिज़ाइन की क्षमता को पहचान सकती हैं.
मटीरियल कॉम्पोनेंट (एमडीसी), मटीरियल डिज़ाइन लागू करने में डेवलपर की मदद करते हैं. Google में इंजीनियरों और UX डिज़ाइनर की टीम ने बनाया है. एमडीसी में दर्जनों खूबसूरत और काम करने वाले यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट हैं. यह Android, iOS, वेब और Flutter.material.io/प्रॉडक्ट के लिए उपलब्ध है |
Android के लिए Material का मोशन सिस्टम क्या है?
Android के लिए मटीरियल मोशन सिस्टम, एमडीसी-Android लाइब्रेरी में ट्रांज़िशन पैटर्न का एक सेट है. इससे उपयोगकर्ताओं को ऐप्लिकेशन को समझने और नेविगेट करने में मदद मिलती है. इस बारे में मटीरियल डिज़ाइन से जुड़े दिशा-निर्देश में बताया गया है.
चार मुख्य मटीरियल ट्रांज़िशन पैटर्न इस तरह हैं:
- कंटेनर ट्रांसफ़ॉर्म: यूज़र इंटरफ़ेस (यूआई) एलिमेंट के बीच ट्रांज़िशन करता है जिनमें कंटेनर शामिल होता है; एक एलिमेंट को दूसरे एलिमेंट में आसानी से बदलकर, दो अलग-अलग यूज़र इंटरफ़ेस (यूआई) एलिमेंट के बीच दिखने वाला कनेक्शन बनाता है.
- शेयर किया गया ऐक्सिस: यूज़र इंटरफ़ेस (यूआई) एलिमेंट के बीच ऐसे ट्रांज़िशन जो जगह या नेविगेशन से जुड़े होते हैं; एलिमेंट के बीच संबंध को समझाने के लिए, x, y या z ऐक्सिस पर शेयर किए गए बदलाव का इस्तेमाल किया जाता है.
- फ़ेड थ्रू: यूज़र इंटरफ़ेस (यूआई) एलिमेंट के बीच ऐसे ट्रांज़िशन जिनका एक-दूसरे से बेहतर संबंध नहीं है; आने वाले एलिमेंट के स्केल के साथ, क्रम में फ़ेड आउट और फ़ेड इन का इस्तेमाल करता है.
- फ़ेड: इसका इस्तेमाल यूज़र इंटरफ़ेस (यूआई) एलिमेंट के लिए किया जाता है, जो स्क्रीन की सीमाओं के अंदर से जुड़ते हैं या बाहर निकलते हैं.
एमडीसी-Android लाइब्रेरी इन पैटर्न के लिए ट्रांज़िशन क्लास की सुविधा देती है. इन्हें AndroidX ट्रांज़िशन लाइब्रेरी (androidx.transition
) और Android ट्रांज़िशन फ़्रेमवर्क (android.transition
), दोनों के ऊपर बनाया गया है:
AndroidX
com.google.android.material.transition
पैकेज में उपलब्ध है- एपीआई लेवल 14 और उसके बाद के वर्शन के साथ काम करता है
- फ़्रैगमेंट और व्यू के साथ काम करता है, लेकिन ऐक्टिविटी या Windows के साथ नहीं
- इसमें बैकपोर्ट की गई गड़बड़ियां ठीक की गई हैं और एपीआई लेवल पर, लगातार काम करने की सुविधा भी शामिल है
फ़्रेमवर्क
com.google.android.material.transition.platform
पैकेज में उपलब्ध है- एपीआई लेवल 21 और उसके बाद के वर्शन के साथ काम करता है
- फ़्रैगमेंट, व्यू, गतिविधियों, और Windows के साथ काम करता है
- गड़बड़ियां ठीक की गईं
इस कोडलैब में, AndroidX लाइब्रेरी पर सबसे ऊपर बने मटीरियल ट्रांज़िशन का इस्तेमाल किया जा रहा है. इसका मतलब है कि आपको मुख्य रूप से फ़्रैगमेंट और व्यू पर फ़ोकस करना होगा.
आपको क्या बनाना होगा
यह कोडलैब आपको उदाहरण के तौर पर जवाब नाम के Android ईमेल ऐप्लिकेशन में कुछ ट्रांज़िशन करने में मदद करेगा, ताकि आप यह दिखा सकें कि अपने ऐप्लिकेशन के लुक और स्टाइल को पसंद के मुताबिक बनाने के लिए, एमडीसी-Android लाइब्रेरी से ट्रांज़िशन का इस्तेमाल कैसे किया जा सकता है.
जवाब ऐप्लिकेशन के लिए स्टार्टर कोड दिया जाएगा. साथ ही, आपको ऐप्लिकेशन में नीचे दिए गए मटीरियल ट्रांज़िशन शामिल करने होंगे. इन्हें नीचे दिए गए कोडलैब के GIF में देखा जा सकता है:
- कंटेनर ट्रांसफ़ॉर्म का इस्तेमाल, ईमेल सूची से ईमेल की ज़्यादा जानकारी वाले पेज पर किया जाता है
- ईमेल पेज लिखने के लिए, एफ़एबी से कंटेनर ट्रांसफ़ॉर्म का ट्रांज़िशन
- शेयर किया गया Z-ऐक्सिस का खोज आइकॉन से खोज व्यू पेज पर ट्रांज़िशन
- मेलबॉक्स पेजों के बीच फ़ेड थ्रू ट्रांज़िशन
- कंटेनर बदलाव ईमेल पता चिप से कार्ड व्यू में ट्रांज़िशन
आपको इन चीज़ों की ज़रूरत होगी
- Android डेवलपमेंट और Kotlin के बारे में बुनियादी जानकारी
- Android Studio (अगर आपके पास पहले से Android Studio नहीं है, तो इसे यहां से डाउनलोड करें)
- Android Emulator या डिवाइस (Android Studio में उपलब्ध)
- सैंपल कोड (अगला चरण देखें)
Android ऐप्लिकेशन बनाने के अपने अनुभव को आप कितनी रेटिंग देंगे?
2. अपना डेवलपमेंट एनवायरमेंट सेट अप करें
Android Studio शुरू करना
Android Studio खोलने पर, आपको "Android Studio में आपका स्वागत है" टाइटल वाली विंडो दिखेगी. हालांकि, अगर Android Studio को पहली बार लॉन्च किया जा रहा है, तो डिफ़ॉल्ट वैल्यू के साथ Android Studio का सेटअप विज़र्ड के चरणों को पूरा करें. ज़रूरी फ़ाइलों को डाउनलोड और इंस्टॉल होने में इस चरण को पूरा होने में कुछ मिनट लग सकते हैं. इसलिए, अगला सेक्शन चलाते समय, बिना किसी परेशानी के इस प्रोसेस को बैकग्राउंड में चलने दें.
पहला विकल्प: GitHub से स्टार्टर कोडलैब ऐप्लिकेशन का क्लोन बनाना
GitHub से इस कोडलैब का क्लोन बनाने के लिए, नीचे दिए गए निर्देश चलाएं:
git clone https://github.com/material-components/material-components-android-motion-codelab.git cd material-components-android-motion-codelab
विकल्प 2: स्टार्टर कोडलैब ऐप्लिकेशन की ज़िप फ़ाइल डाउनलोड करें
स्टार्टर ऐप्लिकेशन, material-components-android-motion-codelab-develop
डायरेक्ट्री में मौजूद है.
Android Studio में स्टार्टर कोड लोड करना
- सेटअप विज़र्ड पूरा हो जाने और Android Studio में आपका स्वागत है विंडो दिखने के बाद, कोई मौजूदा Android Studio प्रोजेक्ट खोलें पर क्लिक करें.
- प्रोजेक्ट खोलने के लिए, उस डायरेक्ट्री पर जाएं जिसमें आपने सैंपल कोड इंस्टॉल किया था. इसके बाद, सैंपल डायरेक्ट्री चुनें.
- प्रोजेक्ट को बनाने और सिंक करने के लिए, Android Studio को कुछ समय इंतज़ार करें. इस प्रोजेक्ट को Android Studio की विंडो में सबसे नीचे, गतिविधि की जानकारी देने वाले इंडिकेटर में दिखाया गया है.
- ऐसा होने पर, Android Studio आपको बिल्ड से जुड़ी कुछ गड़बड़ियों की जानकारी दे सकता है. इसकी वजह यह है कि आपके पास Android SDK टूल या बिल्ड टूल मौजूद नहीं हैं. इन टूल के बारे में नीचे बताया गया है. इन्हें इंस्टॉल/अपडेट करने और अपने प्रोजेक्ट को सिंक करने के लिए, Android Studio में दिए गए निर्देशों का पालन करें. अगर आपको अब भी समस्याएं आ रही हैं, तो SDK Manager की मदद से अपने टूल अपडेट करने के बारे में बताने वाली गाइड देखें.
प्रोजेक्ट डिपेंडेंसी की पुष्टि करें
प्रोजेक्ट के लिए MDC-Android लाइब्रेरी पर निर्भर होना ज़रूरी है. डाउनलोड किए गए सैंपल कोड में, यह डिपेंडेंसी पहले से मौजूद होनी चाहिए. हालांकि, यह पक्का करने के लिए कॉन्फ़िगरेशन पर नज़र डालते हैं.
app
मॉड्यूल की build.gradle
फ़ाइल पर जाएं और पक्का करें कि dependencies
ब्लॉक में, एमडीसी-Android पर डिपेंडेंसी शामिल हो:
implementation 'com.google.android.material:material:1.2.0'
स्टार्टर ऐप्लिकेशन चलाएं
- पक्का करें कि डिवाइस विकल्प के बाईं ओर बिल्ड कॉन्फ़िगरेशन
app
है. - ऐप्लिकेशन बनाने और चलाने के लिए हरे रंग का Run / Play बटन दबाएं.
- अगर आपके उपलब्ध डिवाइसों की सूची में पहले से कोई Android डिवाइस मौजूद है, तो डिप्लॉयमेंट टारगेट चुनें विंडो में जाकर, सीधे चरण 8 पर जाएं. अगर ऐसा नहीं है, तो नया वर्चुअल डिवाइस बनाएं पर क्लिक करें.
- हार्डवेयर चुनें वाली स्क्रीन पर, Pixel 3 जैसा कोई फ़ोन डिवाइस चुनें और फिर आगे बढ़ें पर क्लिक करें.
- सिस्टम इमेज स्क्रीन पर, Android का सबसे नया वर्शन चुनें. हमारा सुझाव है कि एपीआई लेवल का सबसे नया वर्शन चुनें. अगर उसे इंस्टॉल नहीं किया गया है, तो दिखने वाले डाउनलोड करें लिंक पर क्लिक करें और डाउनलोड पूरा करें.
- आगे बढ़ें पर क्लिक करें.
- Android वर्चुअल डिवाइस (एवीडी) स्क्रीन पर, सेटिंग में कोई बदलाव न करें. इसके बाद, पूरा करें पर क्लिक करें.
- डिप्लॉयमेंट टारगेट डायलॉग से कोई Android डिवाइस चुनें.
- ठीक है पर क्लिक करें.
- Android Studio, ऐप्लिकेशन बनाता है, उसे डिप्लॉय करता है, और टारगेट किए गए डिवाइस पर अपने-आप खोलता है.
हो गया! जवाब दें सुविधा के होम पेज के लिए स्टार्टर कोड, आपके एम्युलेटर में चलना चाहिए. आपको एक इनबॉक्स दिखेगा, जिसमें ईमेल की सूची होगी.
ज़रूरी नहीं: डिवाइस पर चलने वाले ऐनिमेशन की रफ़्तार कम करना
इस कोडलैब में, जल्दी और बेहतर तरीके से बदले गए ट्रांज़िशन शामिल होते हैं. इसलिए, डिवाइस के ऐनिमेशन को धीमा करना मददगार हो सकता है. इससे ट्रांज़िशन की बारीकियों पर नज़र रखी जा सकती है. ऐसा adb
शेल कमांड या क्विक सेटिंग टाइल की मदद से किया जा सकता है. ध्यान दें कि डिवाइस के ऐनिमेशन की रफ़्तार कम करने के इन तरीकों का असर, जवाब देने वाले ऐप्लिकेशन के बाहर डिवाइस पर मौजूद ऐनिमेशन पर भी पड़ेगा.
पहला तरीका: ADB शेल कमांड
डिवाइस के एनिमेशन को 10x के कारक तक धीमा करने के लिए, आप कमांड लाइन से निम्न कमांड चला सकते हैं:
adb shell settings put global window_animation_scale 10
adb shell settings put global transition_animation_scale 10
adb shell settings put global animator_duration_scale 10
डिवाइस की ऐनिमेशन स्पीड को वापस सामान्य पर रीसेट करने के लिए, इन निर्देशों को चलाएं:
adb shell settings put global window_animation_scale 1
adb shell settings put global transition_animation_scale 1
adb shell settings put global animator_duration_scale 1
दूसरा तरीका: क्विक सेटिंग टाइल
इसके अलावा, अगर आपने पहले से ऐसा नहीं किया है, तो सबसे पहले अपने डिवाइस पर डेवलपर सेटिंग को चालू करके, क्विक सेटिंग टाइल को सेट अप करें:
- डिवाइस पर "सेटिंग" खोलें ऐप्स
- नीचे तक स्क्रोल करें और "सिम्युलेट किए गए डिवाइस के बारे में जानकारी" पर क्लिक करें
- नीचे तक स्क्रोल करें और तेज़ी से "बिल्ड नंबर" पर क्लिक करें जब तक डेवलपर सेटिंग चालू नहीं की जातीं
इसके बाद, डिवाइस "सेटिंग" में रहते हुए भी ये काम करें ऐप में क्विक सेटिंग टाइल चालू करने के लिए:
- स्क्रीन पर सबसे ऊपर, खोज आइकॉन या खोज बार पर क्लिक करें
- "टाइल" टाइप करें खोज फ़ील्ड में
- "क्विक सेटिंग डेवलपर टाइल" पर क्लिक करें लाइन
- "विंडो ऐनिमेशन स्केल" पर क्लिक करें स्विच डिवाइस
आखिर में, पूरे कोडलैब के दौरान, स्क्रीन के सबसे ऊपर से सिस्टम नोटिफ़िकेशन शेड को नीचे की ओर खींचें. इसके बाद, धीमी और सामान्य स्पीड वाले ऐनिमेशन के बीच टॉगल करने के लिए, आइकॉन का इस्तेमाल करें.
3. सैंपल ऐप्लिकेशन कोड के बारे में जानें
आइए कोड पर एक नज़र डालें. हमने एक ऐसा ऐप्लिकेशन उपलब्ध कराया है जो Jetpack नेविगेशन कॉम्पोनेंट लाइब्रेरी का इस्तेमाल करके, एक ही ऐक्टिविटी MainActivity में कुछ अलग-अलग फ़्रैगमेंट के बीच नेविगेट करने के लिए करता है:
- Homeफ़्रैगमेंट: ईमेल की सूची दिखाता है
- Emailफ़्रैगमेंट: एक पूरा ईमेल दिखाता है
- Composeफ़्रैगमेंट: नया ईमेल लिखने की सुविधा मिलती है
- Searchफ़्रैगमेंट: यह खोज व्यू दिखाता है
navigation_graph.xml
सबसे पहले, ऐप्लिकेशन का नेविगेशन ग्राफ़ सेट अप करने का तरीका समझने के लिए, navigation_graph.xml
को app -> src -> main -> res -> navigation
डायरेक्ट्री में खोलें:
<navigation xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/navigation_graph"
app:startDestination="@id/homeFragment">
<fragment
android:id="@+id/homeFragment"
android:name="com.materialstudies.reply.ui.home.HomeFragment"
android:label="HomeFragment">
<argument...>
<action
android:id="@+id/action_homeFragment_to_emailFragment"
app:destination="@id/emailFragment" />
</fragment>
<fragment
android:id="@+id/emailFragment"
android:name="com.materialstudies.reply.ui.email.EmailFragment"
android:label="EmailFragment">
<argument...>
</fragment>
<fragment
android:id="@+id/composeFragment"
android:name="com.materialstudies.reply.ui.compose.ComposeFragment"
android:label="ComposeFragment">
<argument...>
</fragment>
<fragment
android:id="@+id/searchFragment"
android:name="com.materialstudies.reply.ui.search.SearchFragment"
android:label="SearchFragment" />
<action
android:id="@+id/action_global_homeFragment"
app:destination="@+id/homeFragment"
app:launchSingleTop="true"
app:popUpTo="@+id/navigation_graph"
app:popUpToInclusive="true"/>
<action
android:id="@+id/action_global_composeFragment"
app:destination="@+id/composeFragment" />
<action
android:id="@+id/action_global_searchFragment"
app:destination="@+id/searchFragment" />
</navigation>
ध्यान दें कि ऊपर बताए गए सभी फ़्रैगमेंट किस तरह मौजूद हैं. इसमें, डिफ़ॉल्ट लॉन्च फ़्रैगमेंट app:startDestination="@id/homeFragment"
के ज़रिए HomeFragment
पर सेट होता है. फ़्रैगमेंट डेस्टिनेशन ग्राफ़ की एक्सएमएल डेफ़िनिशन और कार्रवाइयां, जनरेट किए गए उस Kotlin नेविगेशन कोड की जानकारी देती हैं जो ट्रांज़िशन को हुक अप करते समय आपको मिलेगा.
activity_main.xml
इसके बाद, app -> src -> main -> res -> layout
डायरेक्ट्री में activity_main.xml
के लेआउट पर एक नज़र डालें. आपको NavHostFragment
दिखेगा, जिसे ऊपर दिए गए नेविगेशन ग्राफ़ की मदद से कॉन्फ़िगर किया गया है:
<fragment
android:id="@+id/nav_host_fragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:defaultNavHost="true"
app:navGraph="@navigation/navigation_graph"/>
यह NavHostFragment
पूरी स्क्रीन पर दिखता है और ऐप्लिकेशन में फ़ुल स्क्रीन फ़्रैगमेंट नेविगेशन में किए गए सभी बदलावों को हैंडल करता है. BottomAppBar
और उसके ऐंकर FloatingActionButton
, activity_main.xml
में भी मौजूदा फ़्रैगमेंट के ऊपर रखे जाते हैं, जो NavHostFragment
में दिखाया जाता है. इसलिए, दिए गए सैंपल ऐप्लिकेशन कोड की मदद से, फ़्रैगमेंट डेस्टिनेशन के हिसाब से दिखाया या छिपाया जाता है.
इसके अलावा, activity_main.xml
में मौजूद BottomNavDrawerFragment
एक नीचे वाला पैनल है. इसमें अलग-अलग ईमेल मेलबॉक्स के बीच नेविगेट करने के लिए एक मेन्यू होता है. इसे BottomAppBar
'जवाब दें' लोगो बटन के ज़रिए कुछ शर्तों के साथ दिखाया जाता है.
MainActivity.kt
आखिर में, इस्तेमाल की जा रही नेविगेशन कार्रवाई का उदाहरण देखने के लिए, app -> src -> main -> java -> com.materialstudies.reply.ui
डायरेक्ट्री में MainActivity.kt
खोलें. navigateToSearch()
फ़ंक्शन ढूंढें. यह कुछ ऐसा दिखना चाहिए:
private fun navigateToSearch() {
val directions = SearchFragmentDirections.actionGlobalSearchFragment()
findNavController(R.id.nav_host_fragment).navigate(directions)
}
इस इमेज में दिखाया गया है कि कस्टम ट्रांज़िशन के बिना, खोज व्यू पेज पर कैसे जाया जा सकता है. इस कोडलैब के दौरान, आपको Reply के MainActivity और चार मुख्य फ़्रैगमेंट के बारे में ज़्यादा जानकारी मिलेगी. इससे मटीरियल ट्रांज़िशन को सेट अप किया जा सकेगा, जो पूरे ऐप्लिकेशन में नेविगेशन की अलग-अलग कार्रवाइयों के साथ मिलकर काम करेंगे.
स्टार्टर कोड के बारे में जानने के बाद, अब हम अपना पहला ट्रांज़िशन लागू करेंगे.
4. ईमेल सूची से ईमेल की ज़्यादा जानकारी वाले पेज पर, कंटेनर ट्रांसफ़ॉर्मेशन का ट्रांज़िशन जोड़ें
शुरू करने के लिए, ईमेल पर क्लिक करते ही आपको एक ट्रांज़िशन जोड़ना होगा. नेविगेशन के इस बदलाव के लिए, कंटेनर ट्रांसफ़ॉर्म पैटर्न सबसे सही है, क्योंकि इसे कंटेनर वाले यूज़र इंटरफ़ेस (यूआई) एलिमेंट के बीच ट्रांज़िशन के लिए डिज़ाइन किया गया है. इस पैटर्न से, दो यूज़र इंटरफ़ेस (यूआई) एलिमेंट के बीच कनेक्शन दिखता है.
किसी भी कोड को जोड़ने से पहले, जवाब दें ऐप्लिकेशन को चलाकर और ईमेल पर क्लिक करके देखें. इसे बस जंप-कट किया जाना चाहिए, जिसका मतलब है कि स्क्रीन को बिना किसी ट्रांज़िशन के बदल दिया गया है:
इस स्निपेट में दिखाए गए तरीके से, email_item_layout.xml
के MaterialCardView
पर transitionName
एट्रिब्यूट जोड़कर शुरुआत करें:
email_item_layout.xml
android:transitionName="@{@string/email_card_transition_name(email.id)}"
ट्रांज़िशन का नाम, पैरामीटर के साथ स्ट्रिंग रिसॉर्स में होता है. आपको हर ईमेल के आईडी का इस्तेमाल करना होगा, ताकि यह पक्का किया जा सके कि हमारे EmailFragment
में मौजूद हर transitionName
यूनीक है.
अब आपने ईमेल सूची के आइटम का ट्रांज़िशन नाम सेट कर लिया है. आइए, ईमेल की जानकारी देने वाले लेआउट में ऐसा ही करते हैं. fragment_email.xml
में, MaterialCardView
के transitionName
को इस स्ट्रिंग रिसॉर्स पर सेट करें:
fragment_email.xml
android:transitionName="@string/email_card_detail_transition_name"
HomeFragment.kt
में, अपने स्टार्ट व्यू (ईमेल सूची का आइटम) और एंड व्यू (ईमेल की जानकारी वाली स्क्रीन) से मैपिंग बनाने के लिए, onEmailClicked
में दिए गए कोड को नीचे दिए गए स्निपेट से बदलें:
HomeFragment.kt
val emailCardDetailTransitionName = getString(R.string.email_card_detail_transition_name)
val extras = FragmentNavigatorExtras(cardView to emailCardDetailTransitionName)
val directions = HomeFragmentDirections.actionHomeFragmentToEmailFragment(email.id)
findNavController().navigate(directions, extras)
अब प्लंबिंग कॉन्फ़िगर हो जाने के बाद, आपके पास कंटेनर ट्रांसफ़ॉर्म बनाने का विकल्प है. EmailFragment
onCreate
तरीके में, यह स्निपेट जोड़कर sharedElementEnterTransition
को MaterialContainerTransform
के नए इंस्टेंस पर सेट करें (com.google.android.material.transition.platform
वर्शन के बजाय com.google.android.material.transition
वर्शन इंपोर्ट करना):
EmailFragment.kt
sharedElementEnterTransition = MaterialContainerTransform().apply {
drawingViewId = R.id.nav_host_fragment
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
scrimColor = Color.TRANSPARENT
setAllContainerColors(requireContext().themeColor(R.attr.colorSurface))
}
अब ऐप्लिकेशन को फिर से चलाकर देखें.
चीज़ें ठीक से दिखने लगी हैं! ईमेल सूची में मौजूद किसी ईमेल पर क्लिक करने पर, कंटेनर ट्रांसफ़ॉर्म में आइटम की सूची को फ़ुल स्क्रीन वाले ज़्यादा जानकारी वाले पेज में बड़ा कर दिया जाता है. हालांकि, ध्यान दें कि किस तरह 'वापस जाएं' बटन दबाने से ईमेल, वापस सूची में छोटा नहीं होता. इसके अलावा, ट्रांज़िशन की शुरुआत में ईमेल सूची तुरंत गायब हो जाती है और स्लेटी रंग की विंडो बैकग्राउंड दिखती है. फ़िलहाल, हमारा काम पूरा नहीं हुआ है.
आइटम लौटाने का ट्रांज़िशन ठीक करने के लिए, HomeFragment.kt
में onViewCreated
तरीके की इन दो पंक्तियों को जोड़ें:
HomeFragment.kt
postponeEnterTransition()
view.doOnPreDraw { startPostponedEnterTransition() }
ऐप्लिकेशन को फिर से चलाकर देखें. किसी ईमेल को खोलने के बाद 'वापस जाएं' बटन दबाने पर, वह छोटा हो जाता है और फिर से सूची में शामिल हो जाता है. बढ़िया! आइए, ऐनिमेशन में सुधार करते रहें.
ईमेल सूची गायब होने की समस्या यह है कि नेविगेशन कॉम्पोनेंट का इस्तेमाल करके किसी नए फ़्रैगमेंट पर नेविगेट करते समय, मौजूदा फ़्रैगमेंट तुरंत हटा दिया जाता है और उसकी जगह हमारे नए, इनकमिंग फ़्रैगमेंट का इस्तेमाल किया जाता है. बदलाव किए जाने के बाद भी ईमेल सूची को दिखे, इसके लिए HomeFragment
पर, एग्ज़िट ट्रांज़िशन जोड़ें.
नीचे दिए गए स्निपेट को HomeFragment
onEmailClicked
तरीके में जोड़ें, ताकि बाहर निकलते समय ईमेल की सूची छोटी हो और फिर से डालते समय दिखे:
HomeFragment.kt
exitTransition = MaterialElevationScale(false).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
reenterTransition = MaterialElevationScale(true).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
इसके बाद, यह पक्का करने के लिए कि हैरारकी में हर व्यू के बजाय, पूरी होम स्क्रीन पर MaterialElevationScale
ट्रांज़िशन लागू हो, fragment_home.xml
में मौजूद RecyclerView
को ट्रांज़िशन ग्रुप के तौर पर मार्क करें.
fragment_home.xml
android:transitionGroup="true"
इस चरण में, आपके कंटेनर का ट्रांसफ़ॉर्म पूरी तरह से काम करने वाला होना चाहिए. किसी ईमेल पर क्लिक करने से, सूची में मौजूद आइटम बड़ा हो जाता है, जिससे ईमेल की सूची हट जाती है. 'वापस जाएं' बटन दबाने से ईमेल की जानकारी वाली स्क्रीन फिर से सूची में मौजूद हो जाती है, जबकि ईमेल की सूची बड़ी हो जाती है.
5. ईमेल पेज लिखने के लिए, एफ़एबी से कंटेनर ट्रांसफ़ॉर्म का ट्रांज़िशन जोड़ें
कंटेनर ट्रांसफ़ॉर्म की प्रोसेस जारी रखें और फ़्लोटिंग ऐक्शन बटन से ComposeFragment
में ट्रांज़िशन जोड़ें. ऐसा करते हुए, एफ़एबी को उपयोगकर्ता के लिखे जाने वाले नए ईमेल में बड़ा करते हैं. सबसे पहले, ऐप्लिकेशन को फिर से चलाएं और एफ़एबी पर क्लिक करके देखें कि ईमेल लिखने वाली स्क्रीन को लॉन्च करते समय कोई ट्रांज़िशन नहीं हो रहा.
हम एक ही ट्रांज़िशन क्लास का इस्तेमाल करते हैं. हालांकि, इस इंस्टेंस को कॉन्फ़िगर करने का तरीका अलग होगा, क्योंकि हमारा एफ़एबी MainActivity
में मौजूद है और हमारा ComposeFragment
, MainActivity
नेविगेशन होस्ट कंटेनर में रखा गया है.
ComposeFragment.kt
में, onViewCreated
तरीके में इस स्निपेट को जोड़ें और पक्का करें कि Slide
के androidx.transition
वर्शन को इंपोर्ट किया गया हो.
ComposeFragment.kt
enterTransition = MaterialContainerTransform().apply {
startView = requireActivity().findViewById(R.id.fab)
endView = emailCardView
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
scrimColor = Color.TRANSPARENT
containerColor = requireContext().themeColor(R.attr.colorSurface)
startContainerColor = requireContext().themeColor(R.attr.colorSecondary)
endContainerColor = requireContext().themeColor(R.attr.colorSurface)
}
returnTransition = Slide().apply {
duration = resources.getInteger(R.integer.reply_motion_duration_medium).toLong()
addTarget(R.id.email_card_view)
}
कंटेनर में हुए पिछले ट्रांसफ़ॉर्म को कॉन्फ़िगर करने के लिए इस्तेमाल किए गए पैरामीटर के अलावा, startView
और endView
को यहां मैन्युअल तरीके से सेट किया जा रहा है. 'Android ट्रांज़िशन सिस्टम' को यह बताने के लिए कि किन व्यू को बदलना है, transitionName
एट्रिब्यूट का इस्तेमाल करने के बजाय, ज़रूरत पड़ने पर इन्हें मैन्युअल तौर पर तय किया जा सकता है.
अब, ऐप्लिकेशन को फिर से चलाएं. आपको एफ़एबी को कंपोज़ स्क्रीन में बदलते हुए देखना चाहिए (इस चरण के आखिर में दिया गया GIF देखें).
पिछले चरण की तरह ही, आपको HomeFragment
में एक ट्रांज़िशन जोड़ना होगा, ताकि इसे हटाए जाने और ComposeFragment
से बदलने के बाद वह गायब न हो सके.
नीचे दिए गए स्निपेट को navigateToCompose
तरीके में कॉपी करें. ऐसा MainActivity
में, कॉल NavController
navigate
से पहले करें.
MainActivity.kt
currentNavigationFragment?.apply {
exitTransition = MaterialElevationScale(false).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
reenterTransition = MaterialElevationScale(true).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
}
इस चरण में बस इतना ही! स्क्रीन कंपोज़ करने के लिए, आपको एफ़एबी से कुछ इस तरह ट्रांज़िशन करना होगा:
6. शेयर किए गए Z-ऐक्सिस से ट्रांज़िशन को खोज आइकॉन से खोज व्यू पेज पर जोड़ें
इस चरण में, हम खोज आइकॉन से फ़ुल स्क्रीन में खोज व्यू में ट्रांज़िशन जोड़ेंगे. नेविगेशन के इस बदलाव में कोई स्थायी कंटेनर शामिल नहीं है. इसलिए, हम दो स्क्रीन के बीच के संबंध को बेहतर बनाने के लिए, शेयर किए गए Z-ऐक्सिस ट्रांज़िशन का इस्तेमाल कर सकते हैं. साथ ही, ऐप्लिकेशन के क्रम में एक लेवल ऊपर जाने का संकेत दे सकते हैं.
कोई अन्य कोड जोड़ने से पहले, ऐप्लिकेशन चलाकर देखें. इसके बाद, स्क्रीन पर सबसे नीचे दाएं कोने में मौजूद खोज आइकॉन पर टैप करें. इससे बिना किसी संक्रमण के खोज दृश्य स्क्रीन आ जाएगी.
शुरू करने के लिए, MainActivity
में navigateToSearch
तरीका ढूंढें. इसके बाद, मौजूदा फ़्रैगमेंट के एग्ज़िट को सेट अप करने के लिए, NavController
navigate
तरीके कॉल से पहले यहां दिए गए कोड स्निपेट को जोड़ें और MaterialSharedAxis
Z-ऐक्सिस ट्रांज़िशन फिर से डालें.
MainActivity.kt
currentNavigationFragment?.apply {
exitTransition = MaterialSharedAxis(MaterialSharedAxis.Z, true).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
reenterTransition = MaterialSharedAxis(MaterialSharedAxis.Z, false).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
}
इसके बाद, SearchFragment
के onCreate
तरीके में इस कोड स्निपेट को जोड़ें, जिससे MaterialSharedAxis
ट्रांज़िशन कॉन्फ़िगर होते हैं.
SearchFragment.kt
enterTransition = MaterialSharedAxis(MaterialSharedAxis.Z, true).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
returnTransition = MaterialSharedAxis(MaterialSharedAxis.Z, false).apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
आखिर में, यह पक्का करने के लिए कि हैरारकी में हर व्यू के बजाय, पूरी तरह से खोज स्क्रीन पर MaterialSharedAxis
ट्रांज़िशन लागू हो, fragment_search.xml
में मौजूद LinearLayout
को ट्रांज़िशन ग्रुप के तौर पर मार्क करें.
fragment_search.xml
android:transitionGroup="true"
हो गया! अब ऐप्लिकेशन को फिर से चलाकर देखें और खोज आइकॉन पर टैप करें. होम और खोज व्यू स्क्रीन एक साथ फ़ेड और Z-ऐक्सिस पर स्केल होनी चाहिए, ताकि दोनों स्क्रीन के बीच बिना किसी रुकावट के इफ़ेक्ट दिखे.
7. मेलबॉक्स पेजों के बीच फ़ेड थ्रू ट्रांज़िशन जोड़ना
इस चरण में, हम अलग-अलग मेलबॉक्स के बीच ट्रांज़िशन जोड़ेंगे. हम किसी जगह या पदानुक्रमिक संबंध पर ज़ोर नहीं देना चाहते, इसलिए हम एक आसान "स्वैप" करने के लिए फ़ेड थ्रू का इस्तेमाल करेंगे चुनें.
कोई भी अतिरिक्त कोड जोड़ने से पहले, ऐप्लिकेशन चलाकर देखें. सबसे नीचे ऐप्लिकेशन बार में जवाब दें लोगो पर टैप करें और मेलबॉक्स बदलकर देखें. ईमेल की सूची बिना किसी ट्रांज़िशन के बदलनी चाहिए.
शुरू करने के लिए, MainActivity
में navigateToHome
तरीका ढूंढें. साथ ही, मौजूदा फ़्रैगमेंट के एग्ज़िट MaterialFadeThrough
ट्रांज़िशन सेट अप करने के लिए, NavController
navigate
तरीके कॉल से पहले, यहां दिया गया कोड स्निपेट जोड़ें.
MainActivity.kt
currentNavigationFragment?.apply {
exitTransition = MaterialFadeThrough().apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
}
इसके बाद, HomeFragment
खोलें. onCreate
में, फ़्रैगमेंट के enterTransition
को MaterialFadeThrough
के नए इंस्टेंस पर सेट करें.
HomeFragment.kt
enterTransition = MaterialFadeThrough().apply {
duration = resources.getInteger(R.integer.reply_motion_duration_large).toLong()
}
ऐप्लिकेशन को फिर से चलाएं. नीचे वाला नेविगेशन पैनल खोलने और मेलबॉक्स बदलने पर, ईमेल की मौजूदा सूची फ़ेड और स्केल आउट हो जाएगी. इस दौरान नई सूची धुंधली और स्केल हो जाएगी. बढ़िया!
8. ईमेल पता चिप से कार्ड व्यू में, कंटेनर ट्रांसफ़ॉर्मेशन का ट्रांज़िशन जोड़ें
इस चरण में, आपको ऐसा ट्रांज़िशन जोड़ना होगा जो चिप को पॉप-अप कार्ड में बदल दे. यहां कंटेनर ट्रांसफ़ॉर्म का इस्तेमाल किया जाता है, ताकि उपयोगकर्ता को यह जानकारी दी जा सके कि पॉप-अप में की गई कार्रवाई से, उस चिप पर असर पड़ेगा जिससे पॉप-अप जनरेट हुआ है.
कोई भी कोड जोड़ने से पहले, जवाब देने वाले ऐप्लिकेशन को चलाएं, फिर ईमेल पर क्लिक करें, फिर "जवाब दें" पर क्लिक करें एफ़एबी का इस्तेमाल करें और फिर मैसेज पाने वाले की संपर्क चिप पर क्लिक करके देखें. चिप तुरंत हट जाएगा और उस संपर्क के ईमेल पते वाला एक कार्ड, बिना ऐनिमेशन के पॉप-इन होगा.
इस चरण को पूरा करने के लिए, आपको ComposeFragment
पर काम करना होगा. ComposeFragment
लेआउट में पहले से जोड़ा गया, रिसीपिएंट चिप (डिफ़ॉल्ट रूप से दिखता है) और रिसीपिएंट कार्ड (डिफ़ॉल्ट रूप से नहीं दिखता) हैं. पाने वाले की जानकारी देने वाला चिप और यह कार्ड, वे दो व्यू हैं जिनके बीच का कंटेनर ट्रांसफ़ॉर्मेशन करेगा.
शुरू करने के लिए, ComposeFragment
खोलें और expandChip
तरीका ढूंढें. दिए गए chip
पर क्लिक करने पर, यह तरीका कॉल किया जाता है. recipientCardView
और chip
की विज़िबिलिटी बदलने वाली लाइनों के ऊपर, यह कोड स्निपेट जोड़ें. इससे, beginDelayedTransition
के ज़रिए रजिस्टर किए गए कंटेनर ट्रांसफ़ॉर्म को ट्रिगर किया जाएगा.
ComposeFragment.kt
val transform = MaterialContainerTransform().apply {
startView = chip
endView = binding.recipientCardView
scrimColor = Color.TRANSPARENT
endElevation = requireContext().resources.getDimension(
R.dimen.email_recipient_card_popup_elevation_compat
)
addTarget(binding.recipientCardView)
}
TransitionManager.beginDelayedTransition(binding.composeConstraintLayout, transform)
अगर ऐप्लिकेशन को अभी चलाया जाता है, तो पाने वाले के लिए चिप, ईमेल पतों का एक कार्ड बन जाना चाहिए. अब वापस चिप में कार्ड को छोटा करने के लिए, आइटम वापस करने के ट्रांज़िशन को कॉन्फ़िगर करते हैं.
ComposeFragment
में collapseChip
तरीके में, कार्ड को छोटा करने के लिए, नीचे दिया गया कोड स्निपेट जोड़ें.
ComposeFragment.kt
val transform = MaterialContainerTransform().apply {
startView = binding.recipientCardView
endView = chip
scrimColor = Color.TRANSPARENT
startElevation = requireContext().resources.getDimension(
R.dimen.email_recipient_card_popup_elevation_compat
)
addTarget(chip)
}
TransitionManager.beginDelayedTransition(binding.composeConstraintLayout, transform)
ऐप्लिकेशन को फिर से चलाएं. चिप पर क्लिक करने से, चिप बड़ा हो जाना चाहिए. कार्ड पर क्लिक करने से कार्ड, चिप में वापस छोटा हो जाएगा. बढ़िया!
9. सब हो गया
Kotlin कोड की 100 से कम लाइन और कुछ बेसिक एक्सएमएल मार्कअप का इस्तेमाल करके, MDC-Android लाइब्रेरी ने आपको ऐसे मौजूदा ऐप्लिकेशन में सुंदर ट्रांज़िशन बनाने में मदद की है जो मटीरियल डिज़ाइन के दिशा-निर्देशों के मुताबिक है. साथ ही, यह सभी Android डिवाइसों पर एक जैसा दिखता है और काम करता है.
अगले चरण
मटीरियल मोशन सिस्टम के बारे में ज़्यादा जानकारी के लिए, खास जानकारी और पूरे डेवलपर दस्तावेज़ देखें. साथ ही, अपने ऐप्लिकेशन में कुछ मटीरियल ट्रांज़िशन जोड़कर देखें!
मटीरियल मोशन आज़माने के लिए धन्यवाद. हमें उम्मीद है कि आपको यह कोडलैब पसंद आया होगा!