![](https://developer.android.google.cn/static/images/design/ui/mobile/predictive-back-hero.png?authuser=002&hl=hi)
प्रेडिक्टिव बैक, जेस्चर वाले नेविगेशन ऑपरेशन का नतीजा होता है. इसमें उपयोगकर्ता ने जेस्चर के अपने डेस्टिनेशन को पूरी तरह से पूरा करने से पहले, उसकी झलक देखने के लिए वापस स्वाइप किया होता है. इससे उपयोगकर्ता यह तय कर सकता है कि उसे आगे बढ़ना है या मौजूदा व्यू में रहना है. दूसरे शब्दों में, यह तय करना है कि बैक जेस्चर को "कंप्लीट" करना है या नहीं.
जेस्चर नेविगेशन का इस्तेमाल करते समय, अनुमानित बैक की सुविधा से नेविगेशन का बेहतर और आसान अनुभव मिलता है. यह ऐप्लिकेशन, YouTube में पहले से मौजूद ऐनिमेशन का इस्तेमाल करके, लोगों को यह जानकारी देता है कि उनकी कार्रवाइयों से उन्हें किस तरह के नतीजे मिलेंगे.
अगर आपके ऐप्लिकेशन के डिज़ाइन में, अहम पलों के लिए कस्टम ट्रांज़िशन और ऐनिमेशन के साथ बैक नेविगेशन की सुविधा देनी है, तो इस पेज पर दिए गए डिज़ाइन के दिशा-निर्देशों का इस्तेमाल करें.
'पीछे जाने पर झलक दिखाने वाला हाथ का जेस्चर' सुविधा के लिए सहायता
डिफ़ॉल्ट या कस्टम बैक नेविगेशन का इस्तेमाल करने पर भी, अनुमानित पिछले नेविगेशन की सुविधा उपलब्ध है. अगर डिफ़ॉल्ट 'वापस जाएं' नेविगेशन का इस्तेमाल किया जा रहा है, तो इस सुविधा के लिए आसानी से ऑप्ट-इन किया जा सकता है. अनुमानित बैकअप की सुविधा के बारे में ज़्यादा जानें.
ऑप्ट-इन करने के बाद, आपके ऐप्लिकेशन में पहले से ही ऐनिमेशन मौजूद होते हैं. जैसे, होम स्क्रीन पर वापस जाने, एक ऐक्टिविटी से दूसरी ऐक्टिविटी पर जाने, और एक टास्क से दूसरे टास्क पर जाने के लिए.
Material कॉम्पोनेंट के ये ऐनिमेशन पाने के लिए, Material कॉम्पोनेंट की डिपेंडेंसी को MDC Android के 1.10.0-alpha02 या इसके बाद के वर्शन पर भी अपग्रेड किया जा सकता है:
पक्का करें कि आपके ऐप्लिकेशन में एज-टू-एज (पूरी स्क्रीन) सुविधा काम करती हो
उपयोगकर्ताओं की मदद करने के लिए, अनुमानित वापस जाने के लिए नेविगेशन मेन्यू एज-टू-एज सुविधाओं में बताए गए जेस्चर इनसेट का पालन करता है. इन जेस्चर एरिया में, टच जेस्चर या खींचकर छोड़ने वाले टारगेट न जोड़ें.
![](https://developer.android.google.cn/static/images/design/ui/mobile/predictive-back-1-system-gesture-insets.png?authuser=002&hl=hi)
फ़ुल स्क्रीन सरफ़ेस
अगर आपका ऐप्लिकेशन फ़ुल-स्क्रीन प्लैटफ़ॉर्म के लिए, पसंद के मुताबिक इन-ऐप्लिकेशन ट्रांज़िशन बनाता है, तो डिज़ाइन से जुड़े इन निर्देशों का पालन करें.
पिछले पेज की झलक
जब कोई उपयोगकर्ता फ़ुल-स्क्रीन वाले प्लैटफ़ॉर्म पर, 'वापस जाएं' जेस्चर करता है, तो जेस्चर के आगे बढ़ने के साथ-साथ, इनर एरिया का साइज़ कम होना चाहिए. जैसे ही उपयोगकर्ता कमिट थ्रेशोल्ड को पार करता है, कॉन्टेंट को फ़ेड-थ्रू का इस्तेमाल करके अगले स्टेटस पर स्विच कर देना चाहिए. इससे उपयोगकर्ता को यह पता चलता है कि उसकी कार्रवाई से उसे कहां ले जाया जाएगा.
इंटरपोलेशन
इस्तेमाल किए गए इंटरपोलटर से यह पक्का होता है कि स्क्रीन तुरंत बंद हो जाए. पैरामीटर (.1, .1, 0, 1) हैं जो SystemUI ऐनिमेशन के लिए इस्तेमाल किए गए इंटरपोलेटर से मेल खाते हैं
कार्रवाई रद्द करें
अगर उपयोगकर्ता ने जेस्चर को बिना लागू किए छोड़ दिया है, तो जेस्चर शुरू होने से पहले कॉन्टेंट तुरंत वापस आ जाता है और अपनी मूल स्थिति और साइज़ पर स्केल हो जाता है. साथ ही, स्टेटस में हुए किसी भी बदलाव को पहले जैसा कर देता है.
मोशन की जानकारी
पैरामीटर |
शुरुआती वैल्यू |
टारगेट वैल्यू |
संदर्भ |
---|---|---|---|
स्केल से बाहर निकलना |
100% |
90% |
|
स्केल डालें |
110% |
100% |
|
फ़ेड आउट करना |
100% |
0% |
प्रोग्रेस थ्रेशोल्ड के 35% तक पहुंचने पर, टारगेट वैल्यू पर फ़ेड हो जाता है |
फ़ेड इन करें |
0% |
100% |
फ़ेड-आउट की प्रोसेस, वीडियो के 35% तक चलने के बाद शुरू होती है |
शेयर किए गए एलिमेंट का ट्रांज़िशन
अगर आपका ऐप्लिकेशन, शेयर किए गए एलिमेंट के ट्रांज़िशन के लिए कस्टम इन-ऐप्लिकेशन ट्रांज़िशन बनाता है, तो डिज़ाइन से जुड़े इन दिशा-निर्देशों का इस्तेमाल करें.
जब कोई उपयोगकर्ता किसी शेयर किए गए एलिमेंट के ट्रांज़िशन पर, पीछे जाने का जेस्चर इस्तेमाल करता है, तो बैक प्रीव्यू के दौरान सरफ़ेस, पूरी तरह से स्क्रीन के किनारे से अलग हो जाता है और उपयोगकर्ता इसमें सीधे बदलाव कर सकता है. हालांकि, डिज़ाइन से उपयोगकर्ता को यह नहीं दिखना चाहिए कि बैक जेस्चर करने पर, बैक जेस्चर की दिशा में मौजूद आइटम हट जाता है.
उदाहरण के लिए, जानकारी वाली स्क्रीन को वर्टिकल सूचियों में वापस खारिज करते समय, शेयर किए गए एलिमेंट के ट्रांज़िशन का इस्तेमाल किया जा सकता है. इससे उपयोगकर्ता को यह पता चलता है कि वह पिछली कार्रवाई को पहले जैसा कर रहा है. तीसरे वीडियो में, कैलेंडर इवेंट को हटाकर दिन के व्यू पर वापस ले जाया गया है. टच करने पर बेहतर अनुभव देने के लिए, डिज़ाइन में थोड़ा ओवरशूट जोड़ा गया है, ताकि जेस्चर के दौरान स्प्रिंग में जमा हुई कुछ टेंशन को कम किया जा सके.
पिछले पेज की झलक
उपयोगकर्ता को अनुमानित ऐनिमेशन दिखाते समय, आपके ऐप्लिकेशन में पहले से तय स्थिति को मेज़र किया जाता है. यह स्थिति तब मेज़र की जाती है, जब उपयोगकर्ता ने किनारे से किनारे तक बैक जेस्चर किया हो, लेकिन उसे पूरा न किया हो. आपको ऐसे पैरामीटर देने होंगे जो इस पहले से तय स्थिति पर लागू होते हों.
गति की जानकारी दिखाने वाली मेट्रिक, उस जगह से उपयोगकर्ता की सबसे दूर की जगह के आधार पर तय की जाती है जहां से जेस्चर शुरू हुआ था.
मोशन की जानकारी
शेयर किए गए एलिमेंट के ट्रांज़िशन पर, जेस्चर की शुरुआत से x और y शिफ़्ट का सीधा असर पड़ता है. इस सेक्शन में, स्क्रीन पर दिखने वाले सुझाव, शिकायत या राय के लिए इस्तेमाल किए जाने वाले मैकेनिक्स के बारे में बताया गया है.
यहां दिए गए आंकड़े, प्लैटफ़ॉर्म पर ऐनिमेशन के लिए सुझाई गई मोशन स्पेसिफ़िकेशन दिखाते हैं.
![](https://developer.android.google.cn/static/images/design/ui/mobile/predictive-back-2-surface-scale-left-hand-swiping.png?authuser=002&hl=hi)
1 मार्जिन: दोनों तरफ़ चौड़ाई का 5% (3 में बताए गए सतह के क्षेत्र से जुड़ा है)
2 विंडो को सेंटर में स्केल करने पर, शिफ़्ट का हिसाब लगाया जाता है. ज़रूरी 8 डीपी मार्जिन के लिए कैलकुलेट करें: ((स्क्रीन की चौड़ाई / 20) - 8) डीपी
3 सर्वर साइज़ 90% तक स्केल हो जाता है. इसमें मार्जिन के लिए 10% जगह बचती है (1 देखें)
4 स्क्रीन के किनारे से 8 डीपी का अंतर छोड़ना
हमारा सुझाव है कि एक जैसा अनुभव देने के लिए, सूची में दिए गए पैरामीटर इस्तेमाल करें. हालांकि, कस्टम ऐनिमेशन बनाने के लिए, इनमें बदलाव किया जा सकता है.
पिछली इमेज में, स्क्रीन की चौड़ाई 1280 है, जिससे x-shift 56 dp है. इसका फ़ॉर्मूला यह है:
((1280/20)-8)= 56 डीपी x-शिफ़्ट
![](https://developer.android.google.cn/static/images/design/ui/mobile/predictive-back-3-delta-params-left-hand-swiping.png?authuser=002&hl=hi)
1 y-shift के लिए, एज और डिवाइस मार्जिन के बीच स्पेस उपलब्ध है
2 अगर सरफ़ेस स्क्रीन से हट जाता है, तो सरफ़ेस को 50% से ज़्यादा छोटा न करें.
2 सर्वर वर्टिकल तौर पर बीच में शुरू होता है. इसमें y-shift इस तरह से तय किया जाता है:
- वाई-शिफ़्ट कम रखें, ताकि सतह कभी भी 8 dp स्क्रीन के मार्जिन से आगे न निकल जाए
- सतह को अचानक बंद होने से बचाने के लिए, डिसेलरेट इंटरपोलेटर का इस्तेमाल करें और y-शिफ़्ट की सीमा पर मैप करें
3 जब सतह ज़रूरत के मुताबिक छोटा हो, तब 8 dp मार्जिन को बनाए रखें
कस्टम ऐनिमेशन के लिए, आपको यहां दिए गए सभी पैरामीटर तय करने होंगे.
पैरामीटर |
वैल्यू |
संदर्भ |
---|---|---|
X शिफ़्ट |
((स्क्रीन की चौड़ाई / 20) - 8) डीपी |
ज़्यादा से ज़्यादा शिफ़्ट, 8dp मार्जिन छोड़ता है |
Y शिफ़्ट |
((स्क्रीन की उपलब्ध लंबाई / 20) -8) डीपी |
ज़्यादा से ज़्यादा शिफ़्ट, 8dp मार्जिन छोड़ता है |
स्केल |
90% |
विंडो के साइज़ का कम से कम स्केल |
अनुमानित बैक प्रोग्रेस एपीआई का इस्तेमाल करके कस्टम ऐनिमेशन लागू करने वाले डेवलपर, इन पैरामीटर का इस्तेमाल करते हैं.
जेस्चर की प्रोग्रेस का अनुमान लगाना
उपयोगकर्ता के जेस्चर से, लीनियर प्रोग्रेस वैल्यू का पता लगाया जा सकता है. हालांकि, इसका इस्तेमाल सीधे तौर पर झलक दिखाने वाले एनिमेशन के लिए नहीं किया जाना चाहिए. इसके बजाय, सुझाव या राय इस तरह से दी जानी चाहिए कि उपयोगकर्ता को पिछली कार्रवाई के दौरान मदद मिल सके. प्रोग्रेस वैल्यू को STANDARD_DECELERATE
टोकन या PathInterpolator(0f, 0f, 0f, 1f) के साथ फ़ीड करें, ताकि शुरुआत में जेस्चर ज़्यादा साफ़ तौर पर दिखे. यह फ़ीडबैक, जेस्चर की शुरुआत में गति का पता लगाने की सुविधा को बेहतर बनाता है. साथ ही, विज़ुअल को बेहतर और साफ़ तरीके से कंट्रोल करने के लिए, धीमा करने की सुविधा का इस्तेमाल करता है.
कार्रवाई करने के लिए प्रतिबद्ध होना
जब कोई उपयोगकर्ता, कमिट करने के बाद हाथ हटाता है, तो एक ऐनिमेशन दिखता है. इससे, कार्रवाई पूरी होने की पुष्टि होती है.
जब उपयोगकर्ता तेज़ी से जेस्चर करते हैं, तो इन्हें आम तौर पर फ़्लिंग कहा जाता है. इस तरह के इंटरैक्शन से, स्क्रीन पर मौजूद एलिमेंट पर तेज़ी से असर पड़ सकता है. इसलिए, पिछले झलक के संदर्भ में सिस्टम, तय गतिविधि को दिखाने से पहले सैटलाइट को उसकी सबसे ज़्यादा झलक की स्थिति में दिखाने के लिए, रफ़्तार को सोख लेता है.
फ़्लिंग की क्षमता से तय होता है कि कमिट किए गए ऐनिमेशन को चलाने से पहले झलक दिखाने वाले ऐनिमेशन का कितना हिस्सा दिखाया जाएगा. दिखाया जाने वाला ऐनिमेशन किस तरह का होगा, यह इस बात पर निर्भर करता है कि किस तरह का कॉन्टेंट हटाया जा रहा है. इस बारे में दूसरे वीडियो में बताया गया है.
कार्रवाई रद्द करें
छठे वीडियो में दिखाया गया है कि थ्रेशोल्ड से पहले रिलीज़ करने पर क्या होता है. इसमें एक ऐनिमेशन दिखाया गया है, जिसमें यह पुष्टि की गई है कि कार्रवाई रद्द कर दी गई है. शेयर किए गए एलिमेंट के ट्रांज़िशन के लिए, विंडो तेज़ी से मूव करती है और जेस्चर शुरू होने से पहले, अपनी मूल अवस्था में वापस आ जाती है.