विस्तार करने लायक सूचना बनाएं

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

शुरुआत करने के लिए, सूचना बनाएं में बताए गए तरीके से, सामान्य कॉन्टेंट वाली सूचना बनाएं. इसके बाद, स्टाइल ऑब्जेक्ट के साथ setStyle() को कॉल करें और हर टेंप्लेट के हिसाब से जानकारी दें. जैसा कि यहां दिए गए उदाहरणों में दिखाया गया है.

बड़ी इमेज जोड़ना

अपनी सूचना में कोई इमेज जोड़ने के लिए, NotificationCompat.BigPictureStyle का इंस्टेंस setStyle() में पास करें.

  val notification = NotificationCompat.Builder(context, CHANNEL_ID)
          .setSmallIcon(R.drawable.new_post)
          .setContentTitle(imageTitle)
          .setContentText(imageDescription)
          .setStyle(NotificationCompat.BigPictureStyle()
                  .bigPicture(myBitmap))
          .build()

अगर आपको सूचना को कोलैप्स करने पर, इमेज को सिर्फ़ थंबनेल के तौर पर दिखाना है, तो setLargeIcon() को कॉल करें और उसमें इमेज पास करें. जैसा कि यहां दी गई इमेज में दिखाया गया है. इसके बाद, BigPictureStyle.bigLargeIcon() को कॉल करें और उसमें null पास करें, ताकि सूचना को एक्सपैंड करने पर बड़ा आइकॉन गायब हो जाए:

  val notification = NotificationCompat.Builder(context, CHANNEL_ID)
          .setSmallIcon(R.drawable.new_post)
          .setContentTitle(imageTitle)
          .setContentText(imageDescription)
          .setLargeIcon(myBitmap)
          .setStyle(NotificationCompat.BigPictureStyle()
                  .bigPicture(myBitmap)
                  .bigLargeIcon(null))
          .build()
नीले रंग की इमेज वाली छोटी की गई सूचना और बड़ी की गई सूचना
पहली इमेज. का इस्तेमाल करके बनाई गई सूचनाNotificationCompat.BigPictureStyle.

टेक्स्ट का बड़ा ब्लॉक जोड़ना

सूचना के एक्सपैंड किए गए कॉन्टेंट वाले सेक्शन में टेक्स्ट दिखाने के लिए, NotificationCompat.BigTextStyle लागू करें:

  val notification = NotificationCompat.Builder(context, CHANNEL_ID)
          .setSmallIcon(R.drawable.new_mail)
          .setContentTitle(emailObject.getSenderName())
          .setContentText(emailObject.getSubject())
          .setLargeIcon(emailObject.getSenderAvatar())
          .setStyle(NotificationCompat.BigTextStyle()
                  .bigText(emailObject.getSubjectAndSnippet()))
          .build()
BigTextStyle का इस्तेमाल करके, सूचना को छोटा और बड़ा करके दिखाया गया है
दूसरी इमेज. का इस्तेमाल करके बनाई गई सूचनाNotificationCompat.BigTextStyle.

इनबॉक्स स्टाइल वाली सूचना बनाना

अगर आपको किसी सूचना में, कई छोटी खास जानकारी वाली लाइनें जोड़नी हैं, तो NotificationCompat.InboxStyle लागू करें. जैसे, आने वाले ईमेल के स्निपेट. इससे, कॉन्टेंट के कई ऐसे टेक्स्ट जोड़े जा सकते हैं जिन्हें एक लाइन में छोटा किया गया हो. जबकि NotificationCompat.BigTextStyle में, टेक्स्ट की एक लाइन होती है.

नई लाइन जोड़ने के लिए, addLine() को छह बार तक कॉल करें. जैसा कि यहां दिए गए उदाहरण में दिखाया गया है. अगर छह से ज़्यादा लाइनें जोड़ी जाती हैं, तो सिर्फ़ पहली छह लाइनें दिखती हैं.

  val notification = NotificationCompat.Builder(context, CHANNEL_ID)
          .setSmallIcon(R.drawable.baseline_email_24)
          .setContentTitle("5 New mails from Frank")
          .setContentText("Check them out")
          .setLargeIcon(BitmapFactory.decodeResource(resources, R.drawable.logo))
          .setStyle(
                  NotificationCompat.InboxStyle()
                  .addLine("Re: Planning")
                  .addLine("Delivery on its way")
                  .addLine("Follow-up")
          )
          .build()

नतीजा, यहां दी गई इमेज जैसा दिखता है:

इनबॉक्स स्टाइल वाली बड़ी की गई सूचना
तीसरी इमेज. एक्सपैंड की गई इनबॉक्स स्टाइल वाली सूचना.

सूचना में बातचीत दिखाना

किसी भी संख्या में लोगों के बीच क्रम से भेजे गए मैसेज दिखाने के लिए, NotificationCompat.MessagingStyle लागू करें. यह मैसेजिंग ऐप्लिकेशन के लिए सबसे सही है, क्योंकि यह भेजने वाले के नाम और मैसेज के टेक्स्ट को अलग-अलग हैंडल करके, हर मैसेज के लिए एक जैसा लेआउट उपलब्ध कराता है. साथ ही, हर मैसेज कई लाइनों का हो सकता है.

नया मैसेज जोड़ने के लिए, addMessage() को कॉल करें. इसमें मैसेज का टेक्स्ट, मिलने का समय, और भेजने वाले का नाम पास करें. इस जानकारी को NotificationCompat.MessagingStyle.Message ऑब्जेक्ट के तौर पर भी पास किया जा सकता है. जैसा कि यहां दिए गए उदाहरण में दिखाया गया है:

  val message1 = NotificationCompat.MessagingStyle.Message(
          messages[0].getText(),
          messages[0].getTime(),
          messages[0].getSender())
  val message2 = NotificationCompat.MessagingStyle.Message(
          messages[1].getText(),
          messages[1].getTime(),
          messages[1].getSender())
  val notification = NotificationCompat.Builder(context, CHANNEL_ID)
          .setSmallIcon(R.drawable.new_message)
          .setStyle(
                  NotificationCompat.MessagingStyle(resources.getString(R.string.reply_name))
                  .addMessage(message1)
                  .addMessage(message2))
          .build()
मैसेज के स्टाइल में सूचना
चौथी इमेज. का इस्तेमाल करके बनाई गई सूचनाNotificationCompat.MessagingStyle.

NotificationCompat.MessagingStyle का इस्तेमाल करने पर, setContentTitle() और setContentText() को दी गई कोई भी वैल्यू अनदेखा कर दी जाती है.

बातचीत के ऊपर दिखने वाला टाइटल जोड़ने के लिए, setConversationTitle() को कॉल किया जा सकता है. यह ग्रुप का उपयोगकर्ता की ओर से बनाया गया नाम हो सकता है. अगर इसका कोई खास नाम नहीं है, तो बातचीत में शामिल लोगों की सूची हो सकती है. एक-दूसरे से की जाने वाली चैट के लिए, बातचीत का टाइटल सेट न करें, क्योंकि सिस्टम इस फ़ील्ड के मौजूद होने को इस बात का संकेत मानता है कि बातचीत किसी ग्रुप के साथ हो रही है.

यह स्टाइल, सिर्फ़ Android 7.0 (एपीआई लेवल 24) और उसके बाद के वर्शन वाले डिवाइसों पर लागू होती है. जैसा कि पहले बताया गया है, कंपैटिबिलिटी लाइब्रेरी (NotificationCompat) का इस्तेमाल करने पर, MessagingStyle वाली सूचनाएं, अपने-आप एक्सपैंड की जा सकने वाली सूचना की किसी ऐसी स्टाइल पर फ़ॉल बैक हो जाती हैं जो काम करती है.

चैट की बातचीत के लिए इस तरह की सूचना बनाते समय, सीधे जवाब देने की कार्रवाई जोड़ें.

मीडिया कंट्रोल वाली सूचना बनाना

मीडिया प्लेबैक कंट्रोल और ट्रैक की जानकारी दिखाने के लिए, MediaStyleNotificationHelper.MediaStyle लागू करें.

कंस्ट्रक्टर में, अपना जुड़ा हुआ MediaSession तय करें. इससे Android, आपके मीडिया के बारे में सही जानकारी दिखा पाता है.

ज़्यादा से ज़्यादा पांच आइकॉन बटन दिखाने के लिए, addAction() को पांच बार तक कॉल करें. एल्बम का आर्टवर्क सेट करने के लिए, setLargeIcon() को कॉल करें.

MediaStyle से, कोलैप्स किए गए साइज़ के कॉन्टेंट व्यू में भी बदलाव किया जा सकता है. इसके लिए, तीन ऐक्शन बटन तय किए जा सकते हैं. ये बटन, कोलैप्स किए गए व्यू में भी दिखते हैं. ऐसा करने के लिए, ऐक्शन बटन के इंडेक्स setShowActionsInCompactView() को दें.

यहां दिए गए उदाहरण में, मीडिया कंट्रोल वाली सूचना बनाने का तरीका बताया गया है:

  val notification = NotificationCompat.Builder(context, CHANNEL_ID)
          // Show controls on lock screen even when user hides sensitive content.
          .setVisibility(NotificationCompat.VISIBILITY_PUBLIC)
          .setSmallIcon(R.drawable.ic_stat_player)
          // Add media control buttons that invoke intents in your media service
          .addAction(R.drawable.ic_prev, "Previous", prevPendingIntent) // #0
          .addAction(R.drawable.ic_pause, "Pause", pausePendingIntent) // #1
          .addAction(R.drawable.ic_next, "Next", nextPendingIntent) // #2
          // Apply the media style template.
          .setStyle(MediaStyleNotificationHelper.MediaStyle(mediaSession)
                  .setShowActionsInCompactView(1 /* #1: pause button \*/))
          .setContentTitle("Wonderful music")
          .setContentText("My Awesome Band")
          .setLargeIcon(albumArtBitmap)
          .build()
मीडिया स्टाइल वाली सूचना
पांचवी इमेज. का इस्तेमाल करके बनाई गई सूचनाMediaStyleNotificationHelper.MediaStyle.

अन्य संसाधन

MediaStyle और एक्सपैंड की जा सकने वाली सूचनाओं के बारे में ज़्यादा जानने के लिए, यहां दिए गए रेफ़रंस देखें.