Android 16 में, ज़्यादा जानकारी देने वाले अतिरिक्त मेट्रिक एपीआई शामिल हैं. ये मेट्रिक, टैप करने की कार्रवाइयों को ट्रैक करती हैं. जैसे, बटन पर क्लिक करना, स्क्रोल करना, इंप्रेशन, और विजेट का साइज़ और पोज़िशन.
मुख्य एपीआई AppWidgetEvent
है. हर घंटे में एक बार विजेट के साथ होने वाली गतिविधि को कैप्चर करने वाले पीरियोडिक वर्कर को बनाने के लिए, WorkManager
का इस्तेमाल करें.
क्लिक, स्क्रोल, और इंप्रेशन की अवधि को ट्रैक करने के उदाहरण के लिए, यहां दिया गया स्निपेट देखें.
@RequiresApi(Build.VERSION_CODES_FULL.BAKLAVA_1) fun getWidgetEngagementMetrics(context: Context) { val manager = AppWidgetManager.getInstance(context) val endTime = System.currentTimeMillis() val startTime = endTime - (24 * 60 * 60 * 1000) // a day ago val events = manager.queryAppWidgetEvents(startTime, endTime) if (events.isEmpty()) { Log.d(TAG, "No events found for the given time range.") } val metrics = hashMapOf( "clicks" to 0L, "scrolls" to 0L, "totalImpressionLength" to 0L ) for (event in events) { Log.d(TAG, "Event Start: ${event.start}") Log.d(TAG, "Event End: ${event.end}") val widgetId = event.appWidgetId // Tap actions val clickedIds = event.clickedIds if (clickedIds?.isNotEmpty() == true) { metrics["clicks"] = metrics.getValue("clicks") + clickedIds.size // Log or analyze which components were clicked. for (id in clickedIds) { Log.d(TAG, "Widget $widgetId: Tap event on component with ID $id") } } // Scroll events val scrolledIds = event.scrolledIds if (scrolledIds?.isNotEmpty() == true) { metrics["scrolls"] = metrics.getValue("scrolls") + scrolledIds.size // Log or analyze which lists were scrolled. for (id in scrolledIds) { Log.d(TAG, "Widget $widgetId: Scroll event in list with ID/tag $id") } } // Impressions metrics["totalImpressionLength"] = metrics.getValue("totalImpressionLength") + event.visibleDuration.toMillis() Log.d( TAG, "Widget $widgetId: Impression event with duration " + event.visibleDuration.toMillis() + "ms" ) // Position val position = event.position if (position != null) { Log.d( TAG, "Widget $widgetId: left=${position.left}, right=${position.right}, top=${position.top}, bottom=${position.bottom}" ) } } Log.d("WidgetMetrics", "Metrics: $metrics") }
सिस्टम को बेहतर बनाए रखने के लिए, इवेंट की जानकारी डिफ़ॉल्ट रूप से हर घंटे में एक बार दी जाती है. हालांकि, डिवाइस बनाने वाली कंपनियां रिपोर्टिंग विंडो में बदलाव कर सकती हैं. उदाहरण के लिए, Pixel डिवाइसों पर अगर कोई उपयोगकर्ता आपके विजेट में एक ही सूची को एक घंटे में 10 बार स्क्रोल करता है, तो उस घंटे के लिए सिर्फ़ एक स्क्रोल इवेंट गिना जाएगा.
जांच के लिए, इस एट्रिब्यूट को किसी तय समय पर सेट किया जा सकता है. इसके बाद, अपने टेस्ट डिवाइस को रीस्टार्ट करें. यहां दिए गए उदाहरण में, रिपोर्ट विंडो को 0 मि॰से॰ पर सेट किया गया है. इससे इवेंट की रिपोर्ट तुरंत भेजी जाती है.
adb shell device_config override systemui widget_events_report_interval_ms 0
क्लिक और स्क्रोल की रिपोर्टिंग के लिए कस्टम टैग सेट करने के लिए, अपनी RemoteViews
लेआउट में मौजूद किसी व्यू पर RemoteViews.setAppWidgetEventTag का इस्तेमाल किया जा सकता है. इस पूर्णांक टैग का इस्तेमाल तब किया जाता है, जब इस व्यू पर क्लिक या स्क्रोल करने वाले AppWidgetEvents
के लिए क्वेरी की जाती है.