SDK टूल के रनटाइम में मौजूद विज्ञापन SDK टूल, पब्लिशर के व्यू की हैरारकी को ऐक्सेस नहीं कर सकते.
इसके बजाय, रनटाइम में SDK के अपने व्यू होते हैं. SDK टूल, उन View API का इस्तेमाल नहीं कर सकता जो SDK टूल के रनटाइम के बाहर इस्तेमाल किए जाते हैं. ऐसा इसलिए, क्योंकि विज्ञापन व्यू, ऐप्लिकेशन की विंडो से अटैच नहीं होता. इन एपीआई का इस्तेमाल करके यह तय किया जाता है कि विज्ञापन, उपयोगकर्ता को दिख रहा है या नहीं. इसमें getLocationOnScreen
,
getLocationInWindow
या getVisibility
जैसे Android View API शामिल हैं, जो उम्मीद के मुताबिक वैल्यू नहीं दिखाते.
विज्ञापन दिखने से जुड़े आंकड़ों को मेज़र करने की सुविधा, SDK टूल के रनटाइम की मुख्य ज़रूरी शर्त है. इस डिज़ाइन के प्रस्ताव का मकसद, Open Measurement और मिलती-जुलती मेज़रमेंट सेवाओं के लिए सहायता पाना है. यहां बताए गए समाधान, Attribution Reporting API पर भी लागू हो सकते हैं.
मिलने वाली अनुमतियां
इस डिज़ाइन का मकसद, विज्ञापन दिखाने वाले SDK टूल या मेज़रमेंट पार्टनर को विज्ञापन दिखने से जुड़े इस डेटा का हिसाब लगाने में मदद करना है (नामों में बदलाव हो सकता है):
viewport [Rect]
: यह प्लैटफ़ॉर्म की क्षमताओं के आधार पर, डिवाइस की स्क्रीन या ऐप्लिकेशन विंडो की ज्यामिति दिखाता है.uiContainerGeometry [Rect]
: रेंडर की जा रहीSandboxedSdkView
की ज्यामिति.alpha [float]
: रेंडर किए जा रहेSandboxedSdkView
की ओपैसिटी.onScreenGeometry [Rect]
:uiContainerGeometry
का सबसेट, जोviewport
तक के पैरंट व्यू से क्लिप नहीं किया गया है.occludedGeometry [Rect]
:onScreenGeometry
के वे हिस्से जिन्हें ऐप्लिकेशन की हैरारकी में मौजूद किसी भी व्यू से छिपा दिया गया है. इसमें हर ऑक्लूज़न के लिए एकRect
शामिल होता है. यहSandboxedSdkView onScreenGeometry
से इंटरसेक्शन करने वाले शून्य, एक या उससे ज़्यादा ऐप्लिकेशन व्यू से जुड़ा होता है
ज़रूरी शर्तें
uiContainerGeometry
,onScreenGeometry
, औरoccludedGeometry
की वैल्यू,viewport
के निर्देशांक स्पेस में दिखाई जाती हैं.- विज़िबिलिटी में हुए बदलाव की रिपोर्टिंग, कम से कम इंतज़ार के साथ होती है.
- विज्ञापन दिखने की दर को विज्ञापन व्यू के पूरे लाइफ़साइकल के लिए मेज़र किया जा सकता है. इसमें, विज्ञापन के दिखने की शुरुआत से लेकर आखिर तक की अवधि शामिल है.
डिज़ाइन का प्रस्ताव
यह प्रस्ताव, क्लाइंट और प्रोवाइडर यूआई लाइब्रेरी का इस्तेमाल करके, यूज़र इंटरफ़ेस (यूआई) प्रज़ेंटेशन के काम करने के तरीके पर आधारित है. हम यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी को बड़ा करेंगे, ताकि एसडीके टूल, यूआई सेशन के एक या एक से ज़्यादा ऑब्ज़र्वर को रजिस्टर कर सके. जब भी capabilities सेक्शन में डेटा टाइप में बदलाव करने वाले ज़रूरी इवेंट का पता चलता है, तो ऑब्ज़र्वर को विज्ञापन दिखने की जानकारी मिलेगी. SDK टूल के रनटाइम में मौजूद मेज़रमेंट SDK टूल (OMID और MRAID लागू करने वाले), इस ऑब्ज़र्वर को यूज़र इंटरफ़ेस (यूआई) सेशन से अटैच कर सकते हैं, ताकि यह जानकारी सीधे उन्हें भेजी जा सके. मेज़रमेंट पार्टनर, यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी से मिली जानकारी को, पहले से उपलब्ध कॉन्टेंट के डेटा के साथ जोड़ सकते हैं. जैसे, विज्ञापन क्रिएटिव में इंजेक्ट की गई मेज़रमेंट स्क्रिप्ट का इस्तेमाल करते समय. इससे, JavaScript व्यूबिलिटी इवेंट जनरेट किए जा सकते हैं.
क्लाइंट लाइब्रेरी, ViewTreeObserver
जैसे इवेंट लिसनर की मदद से, विज्ञापन के यूज़र इंटरफ़ेस में होने वाले बदलावों को सुनती है. जब भी यह पता चलता है कि विज्ञापन के यूज़र इंटरफ़ेस (यूआई) में ऐसा बदलाव हुआ है जिससे व्यूबिलिटी मेज़रमेंट पर असर पड़ सकता है, तो क्लाइंट लाइब्रेरी यह जांच करती है कि ऑब्ज़र्वर को पिछली सूचना कब भेजी गई थी. अगर आखिरी अपडेट, अनुमति वाले इंतज़ार (एसडीके टूल की मदद से कॉन्फ़िगर किया जा सकता है, मोबाइल पर कम से कम 200 मिलीसेकंड तक) से ज़्यादा है, तो एक नया AdContainerInfo
ऑब्जेक्ट बनाया जाता है और ऑब्ज़र्वर को सूचना भेजी जाती है. इवेंट पर आधारित यह मॉडल, Android पर मौजूद ज़्यादातर OMID लागू करने के तरीके से किए गए पोलिंग की तुलना में, सिस्टम की परफ़ॉर्मेंस के लिए बेहतर है.
एपीआई
privacysandbox.ui.core लाइब्रेरी में ये जोड़े जाएंगे:
SessionObserver
: आम तौर पर, मेज़रमेंट SDK टूल के ज़रिए लागू किया जाता है. यह privacysandbox.ui के ज़रिए, SDK टूल से मिले सेशन से जुड़ा होता है. इस इंटरफ़ेस की मदद से, मेज़रमेंट SDK टूल, विज्ञापन दिखने से जुड़े सिग्नल की कुछ कैटगरी के लिए ऑप्ट-इन कर पाएगा. इससे, यूज़र इंटरफ़ेस (यूआई) क्लाइंट लाइब्रेरी सिर्फ़ उन सिग्नल को इकट्ठा कर पाती है जिनमें ऑब्ज़र्वर की दिलचस्पी है. यह सिस्टम की परफ़ॉर्मेंस के लिहाज़ से बेहतर होता है.registerObserver()
:Session
क्लास में जोड़ा गया यह तरीका, सेशन का ऐक्सेस रखने वाले किसी भी व्यक्ति को ऑब्ज़र्वर के तौर पर रजिस्टर करने की अनुमति देता है. अगर यूज़र इंटरफ़ेस (यूआई) सेशन खुलने के बाद ऑब्ज़र्वर को रजिस्टर किया जाता है, तो उसे तुरंत कैश मेमोरी में सेव किया गयाAdContainerInfo
भेज दिया जाएगा. अगर उपयोगकर्ता सेशन शुरू होने से पहले रजिस्टर कर लेता है, तो सेशन शुरू होने पर उसेAdContainerInfo
भेजा जाएगा.AdContainerInfo
: यह एक ऐसी क्लास है जिसमें ऐसे गेट्टर होते हैं जिनकी मदद से, ऑब्ज़र्वर ऊपर दिए गए क्षमताओं सेक्शन में दिए गए डेटा टाइप के लिए, विज्ञापन कंटेनर की रीड-ओनली जानकारी पा सकता है. जहां भी संभव होगा, इन getters की रिटर्न वैल्यू,View
और उसके सबक्लास पर मौजूद मौजूदा getters की, पार्सल की जा सकने वाली रिटर्न वैल्यू से मेल खाएगी. अगर विज्ञापन कंटेनर को Jetpack Compose का इस्तेमाल करके बनाया गया है, तो इससे कंटेनर की सेमैटिक प्रॉपर्टी दिखती हैं. इस क्लास का इस्तेमाल, विज्ञापन दिखने से जुड़े MRAID और OMID इवेंट का हिसाब लगाने के लिए किया जा सकता है.SessionObserverotifyAdContainerChanged()
: विज्ञापन दिखने की दर में बदलाव होने पर, ऑब्ज़र्वर को सूचना देने के लिए इसका इस्तेमाल किया जाता है. यहAdContainerInfo
ऑब्जेक्ट पास करता है. जब भी ऐसे इवेंट का पता चलता है जिनका असर, 'सुविधाएं' सेक्शन में दिए गए डेटा टाइप पर पड़ता है, तब इसे ट्रिगर किया जाता है. ध्यान दें: सेशन के तरीकों के अलावा, इस तरीके को भी कॉल किया जा सकता है. उदाहरण के लिए, विज्ञापन का साइज़ बदलने के लिए SDK टूल से अनुरोध करने के लिएSession.notifyResized()
को कॉल किया जाता है. ऐसा होने पर,SessionObserver.notifyAdContainerChanged()
को भी कॉल किया जाता है.SessionObserverotifySessionClosed()
: इससे ऑब्ज़र्वर को यह सूचना मिलती है कि सेशन बंद हो गया है.
आने वाले समय में होने वाले सुधार
अगर ऐप्लिकेशन के साथ छेड़छाड़ की जाती है, तो ऐप्लिकेशन प्रोसेस में चल रहे किसी भी कोड में बदलाव किया जा सकता है. इनमें privacysandbox.ui.client लाइब्रेरी का कोड भी शामिल है. इसलिए, ऐप्लिकेशन प्रोसेस में चलने वाला सिग्नल इकट्ठा करने वाला कोई भी लॉजिक, ऐप्लिकेशन कोड से छेड़छाड़ का शिकार हो सकता है. यह उन SDK टूल के कोड पर भी लागू होता है जिन्हें प्राइवसी सैंडबॉक्स के उपलब्ध होने से पहले डिप्लॉय किया गया था और जो ऐप्लिकेशन प्रोसेस में काम करते हैं. इसलिए, यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी से सिग्नल इकट्ठा करने से, सुरक्षा की स्थिति खराब नहीं होती.
इसके अलावा, SDK टूल के रनटाइम में मौजूद कोड, setTrustedPresentationCallback
नाम के प्लैटफ़ॉर्म एपीआई का इस्तेमाल कर सकता है. इससे, विज्ञापन यूज़र इंटरफ़ेस (यूआई) के प्रज़ेंटेशन के बारे में, फ़्रेमवर्क से ज़्यादा बेहतर गारंटी मिल सकती है. setTrustedPresentationCallback
सर्फ़ेस लेवल पर काम करता है. साथ ही, विज्ञापन यूज़र इंटरफ़ेस (यूआई) वाले प्लैटफ़ॉर्म के बारे में बताने में मदद कर सकता है. इसके लिए, विज्ञापन दिखाने के लिए कम से कम थ्रेशोल्ड तय किए जाते हैं. जैसे, दिखने वाले पिक्सल का प्रतिशत, स्क्रीन पर दिखने का समय या स्केल. इस डेटा की पुष्टि, यूज़र इंटरफ़ेस (यूआई) क्लाइंट लाइब्रेरी से मिले विज्ञापन दिखने की संभावना के डेटा के आधार पर की जा सकती है. इस बारे में ऊपर बताया गया है. फ़्रेमवर्क से मिलने वाला डेटा ज़्यादा भरोसेमंद होता है. इसलिए, यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी के ऐसे किसी भी इवेंट को खारिज किया जा सकता है जिसका डेटा, फ़्रेमवर्क के डेटा से मेल न खाता हो. उदाहरण के लिए, अगर setTrustedPresentationCallback
के लिए दिए गए लिसनर को इस सूचना के साथ शुरू किया जाता है कि स्क्रीन पर विज्ञापन यूज़र इंटरफ़ेस (यूआई) के कोई पिक्सल नहीं दिखाए जा रहे हैं और क्लाइंट यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी, स्क्रीन पर नॉन-ज़ीरो पिक्सल दिखाती है, तो क्लाइंट यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी का डेटा खारिज किया जा सकता है.
सवाल पूछे जा सकते हैं
- आपकी दिलचस्पी किन व्यूबिलिटी सिग्नल में है जिनके बारे में इस जानकारी में नहीं बताया गया है?
- मौजूदा प्रस्ताव के मुताबिक, विज्ञापन दिखने से जुड़े आंकड़े को हर 200 मिलीसेकंड में अपडेट किया जाना चाहिए. हालांकि, ऐसा तब ही किया जाएगा, जब यूज़र इंटरफ़ेस (यूआई) में कोई ज़रूरी बदलाव किया गया हो. क्या यह फ़्रीक्वेंसी आपके लिए सही है? अगर नहीं, तो आपको कितने अंतराल में ईमेल चाहिए?
- क्या आपको
setTrustedPresentationCallback
के डेटा का विश्लेषण खुद करना है या जब वहsetTrustedPresentationCallback
के डेटा से मेल न खाए, तो प्रोवाइडर की यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी को क्लाइंट की यूज़र इंटरफ़ेस (यूआई) लाइब्रेरी से डेटा हटाना है? - विज्ञापन दिखने से जुड़े सिग्नल का इस्तेमाल कैसे किया जाता है? इन सवालों के जवाब देने वाला फ़ीडबैक सबमिट करके, हमें अपने इस्तेमाल के उदाहरणों को समझने में मदद करें.