Android सिस्टम बार

स्टेटस बार और नेविगेशन बार को सिस्टम बार कहा जाता है. ये बैटरी लेवल, समय, और सूचना की चेतावनियों जैसी ज़रूरी जानकारी दिखाते हैं. साथ ही, कहीं से भी डिवाइस के साथ सीधे इंटरैक्ट करने की सुविधा देते हैं.

सिस्टम बार की अहमियत को ध्यान में रखना ज़रूरी है. भले ही, आपने Android OS, इनपुट के तरीकों या डिवाइस की अन्य सुविधाओं के साथ इंटरैक्शन के लिए यूज़र इंटरफ़ेस (यूआई) डिज़ाइन किया हो.

पहली इमेज: सिस्टम बार के पीछे इमेज

सीखने वाली अहम बातें

  • अपने ऐप्लिकेशन को डिज़ाइन करते समय, सिस्टम बार शामिल करें. यूज़र इंटरफ़ेस (यूआई) के सेफ़ ज़ोन, सिस्टम इंटरैक्शन, इनपुट के तरीकों, डिसप्ले कटआउट, स्टेटस बार, कैप्शन बार, नेविगेशन बार, और डिवाइस की अन्य सुविधाओं का ध्यान रखें.

  • सिस्टम की स्थिति और नेविगेशन बार को पारदर्शी या पारभासी रखें. साथ ही, इन बार के पीछे कॉन्टेंट बनाएं, ताकि वह पूरे डिवाइस पर दिखे.

  • टैप जेस्चर या खींचें और छोड़ें टारगेट को जेस्चर इनसेट में जोड़ने से बचें. ये एज-टू-एज और जेस्चर नेविगेशन के साथ काम नहीं करते.

    दूसरी इमेज: सिस्टम जेस्चर इनसेट. टैप करने के लिए बने टारगेट को इन जगहों के नीचे न रखें

सिस्टम बार के पीछे अपना कॉन्टेंट बनाना

ऐप्लिकेशन को किनारे से किनारे तक दिखाने की सुविधा की मदद से, Android ऐप्लिकेशन के यूज़र इंटरफ़ेस (यूआई) को सिस्टम बार के नीचे दिखाता है. इससे, ऐप्लिकेशन का बेहतर अनुभव मिलता है. यह सुविधा, उपयोगकर्ताओं की ओर से अक्सर मांगी जाती है.

इनसेट पर प्रतिक्रिया देकर, कोई ऐप्लिकेशन कॉन्टेंट के ओवरलैप की समस्या को हल कर सकता है. इनसेट से पता चलता है कि आपके ऐप्लिकेशन के कॉन्टेंट को कितना पैड किया जाना चाहिए, ताकि वह Android OS के यूज़र इंटरफ़ेस (यूआई) के हिस्सों, जैसे कि नेविगेशन बार या स्टेटस बार या डिवाइस की फ़िज़िकल सुविधाओं, जैसे कि डिसप्ले कट्स के साथ ओवरलैप न हो. Compose और व्यू में, स्क्रीन के किनारों तक दिखने वाले कॉन्टेंट और इनसेट को मैनेज करने के तरीके के बारे में पढ़ें.

किनारे से किनारे तक इस्तेमाल करने के उदाहरणों के लिए डिज़ाइन करते समय, इनसेट के इन टाइप का ध्यान रखें:

  • सिस्टम बार इनसेट, ऐसे यूज़र इंटरफ़ेस (यूआई) पर लागू होते हैं जिस पर टैप किया जा सकता है और जिसे सिस्टम बार से विज़ुअल तौर पर छिपाया नहीं जाना चाहिए.
  • सिस्टम जेस्चर इनसेट, जेस्चर नेविगेशन वाले उन इलाकों पर लागू होते हैं जिनका इस्तेमाल सिस्टम करता है और जो आपके ऐप्लिकेशन से ज़्यादा प्राथमिकता पाते हैं.

स्टेटस बार

Android पर, स्टेटस बार में सूचना आइकॉन और सिस्टम आइकॉन होते हैं. उपयोगकर्ता, सूचना शेड को ऐक्सेस करने के लिए, स्टेटस बार को नीचे की ओर खींचकर उससे इंटरैक्ट करता है.

तीसरा इलस्ट्रेशन: टॉप ऐप्लिकेशन बार के ऊपर, स्टेटस बार का हाइलाइट किया गया हिस्सा

कॉन्टेक्स्ट, दिन के समय, उपयोगकर्ता की सेट की गई प्राथमिकताओं या थीम, और अन्य पैरामीटर के आधार पर, स्टेटस बार के आइकॉन अलग-अलग दिख सकते हैं. स्टेटस बार के आइकॉन का स्टाइल, नीचे दिए गए उदाहरणों की तरह सेट किया जा सकता है.

चौथी इमेज: हल्के और गहरे रंग वाली थीम में स्टेटस बार के आइकॉन.

पक्का करें कि आपके ऐप्लिकेशन का कॉन्टेंट पूरी स्क्रीन पर दिखे. स्टेटस और नेविगेशन बार को पारदर्शी या पारभासी रखें. साथ ही, एज-टू-एज कॉन्टेंट दिखाएं, जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है.

पांचवीं इमेज: पारदर्शी सिस्टम बार वाला एज-टू-एज ऐप्लिकेशन, स्क्रीन के ज़्यादा से ज़्यादा हिस्से का इस्तेमाल करके आपके कॉन्टेंट को बेहतर तरीके से दिखाने के लिए सबसे सही है.

Android 15 में एज-टू-एज डिसप्ले की सुविधा लागू होती है, ताकि सिस्टम बार डिफ़ॉल्ट रूप से पारदर्शी या पारभासी हों. Android के पुराने वर्शन पर, सिस्टम बार को अपारदर्शी न रखें.

छठी इमेज: अपने कॉन्टेंट को बेहतर बनाने के लिए, उसे पूरे स्क्रीन पर दिखाएं. सिस्टम बार के रंग में

सूचना मिलने पर, आम तौर पर स्टेटस बार में एक आइकॉन दिखता है. इससे उपयोगकर्ता को यह संकेत मिलता है कि सूचनाओं के ड्रॉर में कुछ देखने लायक है. यह आपके ऐप्लिकेशन का आइकॉन या चैनल को दिखाने वाला कोई चिह्न हो सकता है. सूचनाओं का डिज़ाइन देखें.

सातवीं इमेज: स्टेटस बार में सूचना का आइकॉन

स्टेटस बार का स्टाइल सेट करना

enableEdgeToEdge() को कॉल करके पक्का करें कि सभी वर्शन पर स्टेटस बार पारदर्शी हो. कंट्रास्ट के लिए, स्टेटस बार के आइकॉन के रंगों को अपडेट करना न भूलें. उदाहरण के लिए, डार्क आइकॉन बनाने के लिए:

WindowCompat.getInsetsController(window, window.decorView)
    .isAppearanceLightStatusBars = false

कटआउट और स्टेटस बार दिखाना

डिसप्ले का कटआउट, कुछ डिवाइसों पर डिसप्ले के हिस्से में होता है. इससे फ़्रंट-फ़ेसिंग सेंसर के लिए जगह मिलती है. इससे स्टेटस बार के दिखने के तरीके पर असर पड़ सकता है. डिसप्ले के कट्सआउट, डिवाइस बनाने वाली कंपनी के हिसाब से अलग-अलग हो सकते हैं.

डिसप्ले में मौजूद कटिंग आउट के साथ काम करने के तरीके के बारे में पढ़ें.

आठवां इलस्ट्रेशन: डिसप्ले में मौजूद कट्सआउट के उदाहरण

Android पर, उपयोगकर्ता वापस जाएं, होम, और खास जानकारी वाले कंट्रोल का इस्तेमाल करके नेविगेशन को कंट्रोल कर सकते हैं:

  • 'वापस जाएं' बटन दबाने पर, सीधे पिछले व्यू पर वापस पहुंचा जा सकता है.
  • होम स्क्रीन, ऐप्लिकेशन से बाहर निकलकर डिवाइस की होम स्क्रीन पर ट्रांज़िशन करती है.
  • खास जानकारी से पता चलता है कि ऐप्लिकेशन खुले हुए हैं और उन्हें हाल ही में खोला गया है.

उपयोगकर्ता, नेविगेशन बार के अलग-अलग कॉन्फ़िगरेशन में से कोई एक चुन सकते हैं. इनमें जेस्चर नेविगेशन (इसका सुझाव दिया जाता है) और तीन बटन वाला नेविगेशन शामिल है. सबसे अच्छा अनुभव देने के लिए, कई तरह के नेविगेशन का इस्तेमाल करें.

हाथ के जेस्चर (स्पर्श) वाला नेविगेशन

Android 10 (एपीआई लेवल 29) में, जेस्चर नेविगेशन को नेविगेशन के लिए सुझाया गया टाइप माना गया है. हालांकि, उपयोगकर्ता की प्राथमिकता को बदला नहीं जा सकता. जेस्चर नेविगेशन में, वापस जाएं, होम, और खास जानकारी वाले पेज के लिए बटन का इस्तेमाल नहीं किया जाता. इसके बजाय, एक जेस्चर हैंडल दिखाया जाता है. उपयोगकर्ता, स्क्रीन के बाएं या दाएं किनारे से स्वाइप करके पिछली स्क्रीन पर जाते हैं. साथ ही, स्क्रीन के सबसे नीचे से ऊपर की ओर स्वाइप करके होम पर जाते हैं. ऊपर की ओर स्वाइप करके रखें, इससे खास जानकारी वाला पेज खुलेगा.

जेस्चर नेविगेशन, नेविगेशन का एक ऐसा पैटर्न है जिसे मोबाइल और बड़ी स्क्रीन, दोनों के लिए डिज़ाइन किया जा सकता है. उपयोगकर्ता को बेहतरीन अनुभव देने के लिए, जेस्चर नेविगेशन का इस्तेमाल करें. इसके लिए:

  • इसमें किनारे से किनारे तक कॉन्टेंट दिखता है.
  • जेस्चर नेविगेशन इनसेट में इंटरैक्शन या टच टारगेट जोड़ने से बचें.

जेस्चर नेविगेशन को लागू करने के बारे में पढ़ें.

नौवीं इमेज: जेस्चर हैंडल वाला नेविगेशन बार

तीन बटन वाला नेविगेशन

तीन बटन वाले नेविगेशन में, वापस जाएं, होम, और खास जानकारी के लिए तीन बटन होते हैं.

10वीं इमेज: तीन बटन वाला नेविगेशन बार

नेविगेशन बार के अन्य वैरिएशन

Android वर्शन और डिवाइस के हिसाब से, आपके उपयोगकर्ताओं के लिए नेविगेशन बार के अन्य कॉन्फ़िगरेशन उपलब्ध हो सकते हैं. उदाहरण के लिए, दो बटन वाले नेविगेशन में होम और वापस जाएं के लिए दो बटन होते हैं.

11वीं इमेज: दो बटन वाला नेविगेशन बार

नेविगेशन का स्टाइल सेट करना

enableEdgeToEdge() को कॉल करके पक्का करें कि सभी वर्शन पर नेविगेशन बार पारदर्शी या पारभासी हो.

Android 15 और इसके बाद के वर्शन वाले डिवाइसों पर या enableEdgeToEdge() को कॉल करने के बाद, जेस्चर नेविगेशन डिफ़ॉल्ट रूप से पारदर्शी होता है. तीन बटन वाला नेविगेशन डिफ़ॉल्ट रूप से पारदर्शी होता है. अगर यह बड़े स्क्रीन वाले डिवाइस के टास्कबार में है, तो यह अपारदर्शी होता है.

अगर आपके ऐप्लिकेशन में सबसे नीचे ऐप्लिकेशन बार है, तो Window.setNavigationBarContrastEnforced() को false पर सेट करें. इससे यह पक्का किया जा सकेगा कि सबसे नीचे मौजूद ऐप्लिकेशन बार, सिस्टम के नेविगेशन बार के नीचे दिखे. इसके लिए, तीन बटन वाले नेविगेशन में पारदर्शी स्क्रीम लागू नहीं की जाएगी.

Android, जेस्चर नेविगेशन मोड और बटन मोड में, यूज़र इंटरफ़ेस की विज़ुअल सुरक्षा को मैनेज करता है.

  • जेस्चर नेविगेशन मोड: सिस्टम, डाइनैमिक कलर अडैप्टेशन लागू करता है. इसमें, सिस्टम बार के कॉन्टेंट का रंग, उनके पीछे मौजूद कॉन्टेंट के आधार पर बदलता है. नीचे दिए गए उदाहरण में, नेविगेशन बार में मौजूद हैंडल को हल्के रंग के कॉन्टेंट के ऊपर रखने पर, उसका रंग गहरे रंग में बदल जाता है. इसके अलावा, गहरे रंग के कॉन्टेंट के ऊपर हैंडल रखने पर, उसका रंग हल्का हो जाता है.

    पहली इमेज: डाइनैमिक कलर अडैप्टेशन
  • बटन मोड: सिस्टम, बटन नेविगेशन बार के पीछे एक पारदर्शी स्क्रीम लागू करता है. इसे Window.setNavigationBarContrastEnforced() को false पर सेट करके हटाया जा सकता है.

    इमेज 13: डाइनैमिक कलर अडैप्टेशन, जहां सिस्टम बार के पीछे मौजूद कॉन्टेंट के हिसाब से रंग बदलता है

कीबोर्ड और नेविगेशन

इमेज 14: नेविगेशन बार वाला ऑन-स्क्रीन कीबोर्ड

हर तरह का नेविगेशन, ऑन-स्क्रीन कीबोर्ड के हिसाब से काम करता है, ताकि उपयोगकर्ता कुछ कार्रवाइयां कर सके. जैसे, कीबोर्ड को खारिज करना या उसकी टाइप बदलना. कीबोर्ड के ट्रांज़िशन को आसान बनाने के लिए, WindowInsetsAnimationCompat का इस्तेमाल करें. इससे ऐप्लिकेशन के ट्रांज़िशन को स्क्रीन के सबसे नीचे से ऊपर और नीचे की ओर स्लाइड करने वाले कीबोर्ड के साथ सिंक किया जा सकता है.

इमर्सिव मोड

इमेज 15: लैंडस्केप मोड वाले मोबाइल डिवाइस पर, फ़ुल-स्क्रीन अनुभव दिखाने वाला इमर्सिव मोड

फ़ुल-स्क्रीन मोड में ऐप्लिकेशन इस्तेमाल करने के लिए, सिस्टम बार छिपाए जा सकते हैं. उदाहरण के लिए, जब कोई उपयोगकर्ता फ़िल्म देख रहा हो. हालांकि, उपयोगकर्ता अब भी सिस्टम बार और यूज़र इंटरफ़ेस (यूआई) को टैप करके देख सकता है, ताकि वह सिस्टम कंट्रोल पर नेविगेट कर सके या उनसे इंटरैक्ट कर सके. फ़ुल स्क्रीन मोड के लिए डिज़ाइन करने के बारे में ज़्यादा जानें या इमर्सिव मोड के लिए सिस्टम बार छिपाने के तरीके के बारे में पढ़ें.