रिच कॉन्टेंट पाएं

पहला डायग्राम. यूनिफ़ाइड एपीआई, आने वाले कॉन्टेंट को मैनेज करने के लिए एक ही जगह उपलब्ध कराता है. इससे कोई फ़र्क़ नहीं पड़ता कि यूज़र इंटरफ़ेस (यूआई) का इस्तेमाल कैसे किया जा रहा है. जैसे, टच करके रखें और मेन्यू से चिपकाएं या खींचें और छोड़ें.

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

यूज़र इंटरफ़ेस (यूआई) कॉम्पोनेंट में, OnReceiveContentListener जैसे इंटरफ़ेस को अटैच किया जा सकता है. साथ ही, किसी भी तरीके से कॉन्टेंट डालने पर कॉलबैक पाया जा सकता है. कॉलबैक, आपके कोड के लिए एक ही जगह बन जाता है, जहां वह सारा कॉन्टेंट मैनेज करता है. जैसे, सादा और स्टाइल वाला टेक्स्ट, मार्कअप, इमेज, वीडियो, ऑडियो फ़ाइलें वगैरह.

Android के पुराने वर्शन के साथ काम करने के लिए, यह एपीआई AndroidX में भी उपलब्ध है. यह Core 1.7 और Appcompat 1.4 से शुरू होता है. हमारा सुझाव है कि इस सुविधा को लागू करते समय, इसका इस्तेमाल करें.

खास जानकारी

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

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

OnReceiveContentListener एपीआई, लागू करने के लिए एक एपीआई बनाकर, इन अलग-अलग कोड पाथ को एक साथ जोड़ता है. इससे, आपके पास अपने ऐप्लिकेशन के लॉजिक पर फ़ोकस करने का विकल्प होता है और बाकी काम प्लैटफ़ॉर्म को करने दिया जा सकता है:

आसानी से इस्तेमाल किए जा सकने वाले यूनिफ़ाइड एपीआई को दिखाने वाली इमेज
तीसरा डायग्राम. यूनिफ़ाइड एपीआई की मदद से, एक ऐसा एपीआई लागू किया जा सकता है जो सभी यूज़र इंटरफ़ेस (यूआई) के साथ काम करता है.

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

लागू करना

एपीआई, एक तरीके वाला लिसनर इंटरफ़ेस है, OnReceiveContentListener. Android प्लैटफ़ॉर्म के पुराने वर्शन के साथ काम करने के लिए, हमारा सुझाव है कि आप AndroidX कोर लाइब्रेरी में, मिलते-जुलते OnReceiveContentListener इंटरफ़ेस का इस्तेमाल करें.

एपीआई का इस्तेमाल करने के लिए, यह बताकर लिसनर लागू करें कि आपका ऐप्लिकेशन किस तरह का कॉन्टेंट मैनेज कर सकता है:

Kotlin

object MyReceiver : OnReceiveContentListener {
    val MIME_TYPES = arrayOf("image/*", "video/*")
    
    // ...
    
    override fun onReceiveContent(view: View, payload: ContentInfoCompat): ContentInfoCompat? {
        TODO("Not yet implemented")
    }
}

Java

public class MyReceiver implements OnReceiveContentListener {
     public static final String[] MIME_TYPES = new String[] {"image/*", "video/*"};
     // ...
}

आपके ऐप्लिकेशन पर काम करने वाले कॉन्टेंट के सभी MIME टाइप तय करने के बाद, बाकी के Listener लागू करें:

Kotlin

class MyReceiver : OnReceiveContentListener {
    override fun onReceiveContent(view: View, contentInfo: ContentInfoCompat): ContentInfoCompat {
        val split = contentInfo.partition { item: ClipData.Item -> item.uri != null }
        val uriContent = split.first
        val remaining = split.second
        if (uriContent != null) {
            // App-specific logic to handle the URI(s) in uriContent.
        }
        // Return anything that your app didn't handle. This preserves the
        // default platform behavior for text and anything else that you aren't
        // implementing custom handling for.
        return remaining
    }

    companion object {
        val MIME_TYPES = arrayOf("image/*", "video/*")
    }
}

Java

 public class MyReceiver implements OnReceiveContentListener {
     public static final String[] MIME_TYPES = new String[] {"image/*", "video/*"};

     @Override
     public ContentInfoCompat onReceiveContent(View view, ContentInfoCompat contentInfo) {
         Pair split = contentInfo.partition(
                 item -> item.getUri() != null);
         ContentInfo uriContent = split.first;
         ContentInfo remaining = split.second;
         if (uriContent != null) {
             // App-specific logic to handle the URI(s) in uriContent.
         }
         // Return anything that your app didn't handle. This preserves the
         // default platform behavior for text and anything else that you aren't
         // implementing custom handling for.
         return remaining;
     }
 }

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

लिसनर लागू करने के बाद, इसे अपने ऐप्लिकेशन में सही यूज़र इंटरफ़ेस (यूआई) एलिमेंट पर सेट करें:

Kotlin

class MyActivity : Activity() {
    public override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        // ...
        val myInput = findViewById(R.id.my_input)
        ViewCompat.setOnReceiveContentListener(myInput, MyReceiver.MIME_TYPES, MyReceiver())
    }
}

Java

public class MyActivity extends Activity {
     @Override
     public void onCreate(Bundle savedInstanceState) {
         // ...

         AppCompatEditText myInput = findViewById(R.id.my_input);
         ViewCompat.setOnReceiveContentListener(myInput, MyReceiver.MIME_TYPES, new MyReceiver());
     }
}

यूआरआई की अनुमतियां

OnReceiveContentListener को भेजे गए पेलोड में मौजूद किसी भी कॉन्टेंट यूआरआई के लिए, प्लैटफ़ॉर्म पढ़ने की अनुमतियां अपने-आप देता है और उन्हें रिलीज़ कर देता है.

आम तौर पर, आपका ऐप्लिकेशन किसी सेवा या गतिविधि में कॉन्टेंट यूआरआई को प्रोसेस करता है. लंबे समय तक चलने वाली प्रोसेस के लिए, WorkManager का इस्तेमाल करें. इसे लागू करने पर, टारगेट की गई सेवा या गतिविधि को अनुमतियां दें. इसके लिए, Intent.setClipData का इस्तेमाल करके कॉन्टेंट पास करें और फ़्लैग FLAG_GRANT_READ_URI_PERMISSION को सेट करें.

इसके अलावा, कॉन्टेंट को प्रोसेस करने के लिए, मौजूदा कॉन्टेक्स्ट में बैकग्राउंड थ्रेड का इस्तेमाल किया जा सकता है. इस मामले में, आपको Listener को मिले payload ऑब्जेक्ट का रेफ़रंस बनाए रखना होगा. इससे यह पक्का करने में मदद मिलेगी कि प्लैटफ़ॉर्म, अनुमतियों को समय से पहले रद्द न करे.

कस्टम व्यू

अगर आपका ऐप्लिकेशन कस्टम View सबक्लास का इस्तेमाल करता है, तो पक्का करें कि OnReceiveContentListener को बायपास न किया गया हो.

अगर आपकी View क्लास, onCreateInputConnection वाले तरीके को बदल देती है, तो InputConnection को कॉन्फ़िगर करने के लिए, Jetpack API InputConnectionCompat.createWrapper का इस्तेमाल करें.

अगर आपकी View क्लास, onTextContextMenuItem वाले तरीके को बदल देती है, तो मेन्यू आइटम के R.id.paste या R.id.pasteAsPlainText होने पर, सुपर को काम सौंपें.

कीबोर्ड इमेज एपीआई के साथ तुलना

OnReceiveContentListener एपीआई को, मौजूदा कीबोर्ड इमेज एपीआई के अगले वर्शन के तौर पर देखा जा सकता है. यह यूनिफ़ाइड एपीआई, कीबोर्ड इमेज एपीआई की सुविधाओं के साथ-साथ कुछ अन्य सुविधाओं के साथ काम करता है. डिवाइस और सुविधा के साथ काम करने की क्षमता इस बात पर निर्भर करती है कि आपने Android SDK टूल की Jetpack लाइब्रेरी का इस्तेमाल किया है या नेटिव एपीआई का.

टेबल 1. Jetpack के लिए काम करने वाली सुविधाएं और एपीआई लेवल.
कार्रवाई या सुविधा कीबोर्ड इमेज एपीआई के साथ काम करता है यह सुविधा, यूनिफ़ाइड एपीआई के साथ काम करती है
कीबोर्ड से शामिल करना हां (एपीआई लेवल 13 और उसके बाद के वर्शन) हां (एपीआई लेवल 13 और उसके बाद के वर्शन)
दबाकर रखने पर दिखने वाले मेन्यू में जाकर, चिपकाने की सुविधा का इस्तेमाल करके टेक्स्ट डालना नहीं हां
खींचें और छोड़ें सुविधा का इस्तेमाल करके शामिल करना नहीं हां (एपीआई लेवल 24 और उसके बाद के वर्शन)
टेबल 2. नेटिव एपीआई के लिए काम करने वाली सुविधाएं और एपीआई लेवल.
कार्रवाई या सुविधा कीबोर्ड इमेज एपीआई के साथ काम करता है यह सुविधा, यूनिफ़ाइड एपीआई के साथ काम करती है
कीबोर्ड से शामिल करना हां (एपीआई लेवल 25 और उसके बाद के वर्शन) हां (Android 12 और उसके बाद के वर्शन)
दबाकर रखने पर दिखने वाले मेन्यू में जाकर, चिपकाने की सुविधा का इस्तेमाल करके टेक्स्ट डालना नहीं
खींचें और छोड़ें सुविधा का इस्तेमाल करके शामिल करना नहीं