Con Android 8.0 (nivel de API 26) y versiones posteriores, puedes permitir que los usuarios fijen tus widgets a la pantalla principal dentro de tu app. Promocionar widgets directamente en tu app es una excelente manera de aumentar la participación de los usuarios, especialmente después de que un usuario completa una tarea relacionada o cuando un usuario accede repetidamente a una función en tu app.
Cómo crear una solicitud de fijación
Para iniciar la fijación de widgets, usa el método requestPinGlanceAppWidget
de la clase GlanceAppWidgetManager
. Para las apps que se ejecutan en versiones anteriores de Android, se devuelve false. Sin embargo, si la solicitud se envía correctamente al sistema, se devuelve el valor verdadero.
A continuación, se muestra un ejemplo de cómo puedes crear una solicitud de PIN:
@Composable fun AnInAppComposable() { val context = LocalContext.current val coroutineScope = rememberCoroutineScope() Button( onClick = { coroutineScope.launch { GlanceAppWidgetManager(context).requestPinGlanceAppWidget( receiver = MyWidgetReceiver::class.java, preview = MyWidget(), previewState = DpSize(245.dp, 115.dp) ) } } ) {} }
En este ejemplo, MyWidgetReceiver
es la clase que recibe las devoluciones de llamada del widget, y MyWidget
es el widget de Glance que quieres fijar. El successCallback
es un PendingIntent
que se activa cuando el widget se fija correctamente.
Cómo controlar la respuesta a la solicitud de PIN
Cuando un usuario responde el diálogo de solicitud de PIN, tu app recibe una respuesta. Si el usuario acepta la solicitud, tu widget se fijará en su pantalla principal y se activará el successCallback
PendingIntent
. Si el usuario rechaza la solicitud, no sucede nada.
Es importante tener en cuenta que el objeto successCallback
solo se activa si el widget se agrega correctamente a la pantalla principal. No se activa si el usuario rechaza la solicitud o si el selector no admite la fijación.