Unlimited WordPress themes, graphics, videos & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Code
  2. Android SDK
Code

Codificar Su Primer Android Slice y Mantener los Usuarios Comprometidos

by
Difficulty:AdvancedLength:LongLanguages:

Spanish (Español) translation by Jean Perez (you can also view the original English article)

El trabajo no terminado sólo porque su aplicación ha acumulado un montón de descargas y revisiones positivas en la tienda de Google Play. El usuario móvil típico cuenta con decenas de aplicaciones instaladas en su dispositivo, y con nuevas aplicaciones liberadas todo el tiempo, tendrá que trabajar duro para mantener el interés de su audiencia!

Mantener a los usuarios volver a su aplicación es crucial para crear un usuario estable y leal base. Además, si has monetizan su aplicación, entonces la cantidad de tiempo que gastan en su aplicación directamente afecta a cuánto dinero usted hace, pensar cada segundo adicional como otra oportunidad para mostrar un anuncio o tentar al usuario a salpicar hacia fuera en una compra en aplicación !

En la entrada-salida de este año, Google introdujo slices, una nueva característica que promete a los usuarios de la unidad de su aplicación consiguiendo características de su aplicación y contenido frente a ellos en el momento exacto cuando son necesarias más.

Con láminas que será una herramienta importante para conservar su audiencia, ahora es el momento perfecto para obtener cierta experiencia práctica con esta emergente característica de Android. Al final de este artículo, habrá creado una gama de sectores, desde una simple división que inicia una actividad cuando golpeada a través a rodajas más complejas que consiste de iconos, imágenes, redes y múltiples SliceActions.

Sectores: Más Maneras Para Que los Usuarios Disfrutar de Su Aplicación

Similares a los widgets, rebanadas son fragmentos de contenido que aparecen fuera del contexto de aplicación, aumentar la visibilidad de la aplicación y le proporciona más oportunidades para atraer a su público.

Sectores tienen el potencial para aumentar considerablemente la visibilidad de la aplicación, Google promete añadir soporte para láminas para las áreas donde muchos usuarios Android pasan cantidades significativas de tiempo, incluyendo el Asistente de Google y Google search. Ya que son parte de Android Jetpack, rebanadas son compatibles con Android 4.4 más alto, que significa que sus rodajas tienen el potencial para alcanzar el 95% de todos los usuarios de Android.

Para Slices tienen mucho que ofrecer, pero ¿cómo funcionan?

En la actualidad, si se realiza una búsqueda en Google app Google podría sugerir una aplicación relevante que está instalada en su dispositivo. Por ejemplo, si has instalado Facebook para el móvil, escribe facebook aparecerá un enlace directo a la aplicación de Facebook.

Androids predictive apps suggest the application users might want to interact with next

Rebanadas de toman esta a un paso más, centrándose en tareas específicas que el usuario puede realizar dentro de las aplicaciones que ya han instalado la aplicación.

Veamos un ejemplo: Imagina que has instalado una aplicación de libro un Hotel que te permite buscar un hotel y reservar una habitación. Cuando escribes Hoteles de Londres en Google, puedes encontrar los resultados de búsqueda habitual, además de una rebanada de la aplicación de libro A Hotel. Este recomienda un hotel en Londres y muestra información como el nombre del hotel y dirección, además de un SliceAction, en la forma de un botón que le permite Reserva una habitación directamente desde la interfaz de usuario de slice (IU).

Para el usuario, este sector ha proporcionado acceso fácil a la información y las características que necesitaban en ese momento. Para el desarrollador, este sector les ha permitido conseguir su aplicación frente a un usuario en el punto exacto cuando se presentaban la mayor probabilidad de éxito volver a participar.

¿Cómo Crear Mi Primera Slice?

Vamos a empezar por crear una simple rebanada que, aprovechado, pondrá en marcha MainActivity de la aplicación.

Esta técnica sencilla permite iniciar cualquier tarea, directamente desde la interfaz de usuario de la división. En nuestro ejemplo del libro A Hotel, podríamos sólo enlazamos el botón a BookRoomActivity de app relacionados con, que sería una forma sencilla pero eficaz para reducir el número de pantallas que el usuario tiene que navegar para completar esta tarea.

Para empezar, cree un nuevo proyecto Android. Usted puede usar cualquier configuración que quiera, pero asegúrese de que selecciona el Kotlin incluyen ayuda casilla de verificación cuando se le solicite.

Una vez que has creado tu proyecto, abra su archivo build.gradle y añadir las dependencias de la base de slice-core y slice-builder:

Mostrando Su Aplicación Contenido en la Búsqueda de Google, Con los Proveedores del Sector

A continuación, necesitamos crear un proveedor de slice, que es el componente responsable de mostrar el contenido de su aplicación fuera del contexto de aplicación.

Crear un proveedor de rodaja con plantilla de proveedor de Studio Android slice:

  • Seleccione Nuevo > Otros > proveedor de Slice de la barra de herramientas de estudio Android.
  • Escriba el nombre MySliceProvider.
  • Configurar el Idioma de origen a Kotlin.
  • Haga clic en Finalizar.
  • Abrir la clase MySliceProvider, y usted debería ver el siguiente código generado automáticamente:

Si crea su proveedor de rodaja con Nueva > Otros > Proveedor de Slice, luego Android Studio también añadirá el proveedor necesario a su manifiesto:

Esta entrada se asegura que su sector se puede descubrir por otras aplicaciones.

¿Ha Fallado la Sincronización de Gradle Proyecto?

Hasta ahora, sólo hemos utilizado código que estudio Android ha generado automáticamente, pero el proyecto ya puede ser negarse a compilar!

Errores, falta de funcionalidad y un comportamiento extraño son sólo una parte de la diversión de trabajar con las primeras versiones. En el momento de la escritura, generar un proveedor de rodaja a veces inexplicablemente añadiría un nuevo conjunto de dependencias para el archivo del proyecto build.gradle.

No sólo son estas dependencias innecesarias, que están mal. Aunque es fácil perder, comparar:

Con el correcto:

Un solo s puede significar la diferencia entre una aplicación de funcionamiento y un proyecto que se niega a compilar. Lo más probable es que este fallo se abordarán antes del lanzamiento oficial de rebanadas, pero si estudio Android comienza a quejarse de dependencias no resueltas luego archivo build.gradle para ver si esto ha sucedido en su proyecto.

Construir un Slice: URIs, SliceActions y Diseño Slice

Para convertir código de modelo de proveedor de rodaja en un sector de funcionamiento, tenemos que hacer varios cambios:

1. Definir una URI

Cada rebanada tiene una URI única, y es trabajo del proveedor de rodaja para proporcionar la asignación entre este URI y el segmento correspondiente.

Aplicaciones que son capaces de mostrar una rebanada se conocen como aplicaciones de host. Cada vez que un huésped necesita mostrar una rebanada, envía una solicitud de enlace al proveedor de rodaja con el URI de la rebanada que está buscando. Su proveedor de rodaja luego Compruebe el identificador URI y devolver el segmento apropiado.

En el siguiente fragmento de código, el método onBindSlice es comprobando la ruta /myURI y regresar a un sector que muestra un mensaje Hola Mundo.

2. Hacer Su Slice Interactiva

Mientras que se puede crear un segmento que simplemente muestra algo de información, si usted quiere su rebanada a ser interactiva entonces usted necesitará crear uno o más SliceActions.

Un SliceAction puede consistir en un título, un icono y un PendingIntent. También puede marcar SliceActions como acciones primarias, que se activan cuando el usuario golpea en cualquier lugar en la fila de la división.

3. Construir la UI de Slice

Definir diseño de slice implementar un ListBuilder, añadiendo una fila, y luego agregar elementos a esa fila. Por ejemplo, aquí estoy utilizando ListBuilder y addRow para crear un segmento que consta de un título y un subtítulo:

Puede mostrar una mezcla de distintos tipos de contenidos en la misma fila, como los iconos, texto y acciones.

Construir Su Primera Slice Android Completamente Funcional

Ahora vamos a aplicar todo esto a nuestro proyecto y crear un segmento que lanza MainActivity nuestra aplicación cuando aprovechado.

Abra la clase MySliceProvider y agregar lo siguiente:

Prueba Tus Slices: Instalar un Visor de Slice

Si vas a poner tus rebanadas a la prueba, entonces necesitarás al menos una aplicación que es capaz de mostrar rebanadas.

Rebanadas al parecer hará su debut en Google buscar finales de este año, pero en el momento de la escritura, esta función aún no había rodado hacia fuera. Actualmente, la única manera de probar rodajas es instalar aplicación de visor de rebanada de Google, que está diseñada para emular cómo rebanadas finalmente aparecerá en la búsqueda de Google.

Instalar Visor de Slice en un Dispositivo Virtual Android (AVD):

  • Descargar Aplicación de Google Slice Viewer.
  • Asegúrese de que su AVD ya está en marcha.
  • Buscar el archivo APK de visor de rebanada y arrastre y suelte en la AVD.

Instalar Visor de Slice en un físico smartphone o tablet:

  • Descargar Slice Viewer.
  • Asegúrese de que su teléfono inteligente o tablet está conectado a tu máquina de desarrollo.
  • Mover la rebanada visor de APK a la carpeta de Android/sdk/platform-tools del ordenador.
  • Abra un Símbolo del Sistema (Windows) o la Ventana de Terminal (Mac).
  • Cambie el directorio (cd) para que el indicador de comandos o Terminal está apuntando a la carpeta Android/sdk/plataforma-herramientas, por ejemplo, este es mi mandamiento:
  • Ejecute el comando, pulsando la tecla Enter en su teclado.
  • Uso del adb install comando para empujar el APK a tu dispositivo Android:

Crear una Configuración de Ejecución de URI

A continuación, debe crear una configuración de ejecución que pasa URI único de la división a su dispositivo AVD o Android.

  • Seleccione Ejecutar > Editar Configuraciones... desde la barra de herramientas de estudio Android.
  • Haga clic + botón y a continuación, seleccione Aplicación para Android.
Create a run configuration by navigating to Run Edit configurations Android App
  • Dar la configuración de ejecución un nombre. Estoy usando sliceConfig.
  • Abrir el menú desplegable del Módulo y seleccione la Aplicación.
  • Abrir el menú desplegable de Lanzamiento y luego seleccione URL.
  • Ingrese URL de la división, en el formato slice-content://package-name/slice-URL. Por ejemplo, es la URL de mi slice: slice-content://com.jessicathornsby.kotlinslices/launchMainActivity.
  • Haga clic en Aceptar.
  • Seleccione Ejecutar > Ejecutar sliceConfig desde la barra de herramientas de Studio Android y luego seleccionar tu dispositivo Android.

Primera vez que rebanada espectador intenta mostrar su rebanada, te solicita permiso a URI único de su segmento. Pulse Permitir y navegar el diálogo de los permisos, y su rebanada debe aparecer en pantalla.

The first time you try to display your slice Slice Viewer will request permission to display your applications slices

Para interactuar con el SliceAction, clic en el botón Open MainActivity y responderá a la rebanada con el lanzamiento MainActivity de su aplicación.

Cada Vez Más Fuera de Sus Slices: Adición de un Segundo SliceAction

¿Por qué limitarte a una SliceAction, cuando usted puede tener múltiples SliceActions? En esta sección, vamos a implementar dos SliceActions, donde cada acción lanza una Actividad diferente. También voy a introducir algunos elementos de interfaz de usuario nueva, añadiendo subtítulos y algunos elementos finales a nuestro sector.

Crear un SecondActivity

Vamos a la configuración del camino y crear una segunda Actividad que nuestro segundo SliceAction puede enlazar a.

En primer lugar, seleccione Nuevo > Archivo de Kotlin / Clase de la barra de herramientas de estudio Android. En el cuadro de diálogo nuevo archivo, abrir el menú de Tipo desplegable y seleccione Clase. Nombre de esta clase SecondActivity y haga clic en Aceptar.

Ahora abra la clase SecondActivity y agregar lo siguiente:

A continuación, seleccione Nuevo > Archivo de Recursos de Android desde la barra de herramientas de estudio Android. En la ventana posterior, abra la lista desplegable de Tipo de Recurso y seleccione Diseño. Nombre este archivo activity_second y haga clic en Aceptar.

Ahora abrir este archivo diseño y agregue el código siguiente:

Abrir manifiesto de su proyecto y declarar este SecondActivity:

Creación de Interfaces Más Complejas: Slice Elementos Finales

Elementos finales pueden ser una marca de tiempo, una imagen o un SliceAction, pero como su nombre indica, siempre aparecen al final de una fila. Puede Agregar múltiples elementos finales a una sola fila, aunque dependiendo del espacio disponible no es posible garantizar que todos sus elementos finales se mostrará al usuario.

Nos va creando nuestra SliceActions como los iconos, así que necesitarás añadir dos nuevo dibujo a su proyecto:

  • Seleccione Nuevo > Activo de Imagen de la barra de herramientas de estudio Android.
  • Haga clic en el pequeño botón de Arte Clip (esto muestra una imagen de un Android por defecto).
  • Seleccione el icono que desea utilizar para el elemento final de Lanzar MainActivity. Estoy usando el icono de Inicio.
  • Dar a este icono de la ic_home nombre y haga clic en Siguiente.
  • Lea la información en pantalla y si eres feliz proceder a continuación haga clic en Finalizar.

Repita los pasos anteriores para crear un icono para su acción de Slice de Lanzar SecondActivity. Para mi segundo punto de la final, estoy usando el icono de call y nombrarlo ic_call.

Creación de la Segunda SliceAction

Ahora estamos listos para añadir un segundo SliceAction a la clase MySliceProvider:

Puesto que no hemos cambiado el URI, no necesitamos crear una nueva configuración de ejecución, lo que prueba esta rebanada es tan simple como seleccionar Run > sliceConfig de la barra de herramientas de estudio Android.

Our slice consists of two end items which are linked to separate SliceActions

Puede descargar este proyecto desde el repositorio de GitHub del tutorial.

Slice de Multimedias: Creación de Diseños de Red

Hasta este punto, hemos construido todos nuestros sectores utilizando sólo las filas, pero también puede crear slices utilizando celdas y filas de cuadrícula.

En esta sección final, vamos a crear un segmento que consta de un título, un subtítulo y una sola fila dividida en tres células. Cada celda tendrá su propio título, un texto y una imagen, y cada uno realizará una acción única cuando aprovechado.

Well be creating a grid-based slice consisting of three unique SliceActions

Para disponer su rebanada en una cuadrícula, es necesario:

  • Implementar un ListBuilder.
  • Agregar una fila de la cuadrícula a ListBuilder, usando addGridRow.
  • Agregar celdas a la fila, utilizando addCell. Cada fila puede mostrar un máximo de cinco celdas.

Puede entonces agregar contenido a cada célula, tales como:

  • Un título, que se agrega mediante addTitleText.
  • Cuerpo del texto, utilizando addText.
  • Imágenes, que se crean mediante addImage. Cada imagen de la célula debe tener uno de los siguientes atributos: LARGE_IMAGE, SMALL_IMAGE o ICON_IMAGE.
  • Una intención de contenido, que es aproximadamente equivalente a un SliceAction. Para evitar que este ejemplo sencillo, aprovechando cada célula se carga simplemente un artículo en el navegador por defecto de los dispositivos, pero si usted prefiere una experiencia más auténtica de sectores puede cambiar el código de setContentIntent.

Voy a incluir algunas imágenes en mi red, así que necesitarás agregar al menos un dibujable a su proyecto. Estoy usando el logo de Kotlin, pero puede tomar cualquier imagen y colocar en la carpeta Drawable de su proyecto.

Ahora, usted está listo para abrir la clase MySliceProvider y construir tu red:

Usted puede encontrar el código completo para este proyecto en nuestro repositorio de GitHub.

Ejecutar esta aplicación en su dispositivo Android física o AVD y tratar de interactuar con cada elemento de la red. Cada célula debe enlazar a un artículo diferente.

Asegurar que Su Slide se Ve Bien, Independientemente de la Aplicación Host

La forma que se muestra el contenido de la división puede variar, dependiendo del modo de para que la aplicación host está configurada. Para asegurar tus rebanadas de buenas aspecto y funcionan correctamente independientemente de la aplicación de hosting, usted necesitará probar sus rebanadas a través de todos los modos de corte diferentes.

Puesto que nuestro segmento de red tiene mucho más contenido que los slices anteriores, es el mejor candidato para ilustrar las diferencias entre estos diversos modos de slice.

Para poner su rebanada a la prueba, haga clic en el icono en la esquina superior derecha de la rebanada espectador y luego recorrer los siguientes modos:

1. Grandes

En este formato, Android muestra tantas filas como sea posible en el espacio disponible. Este es el modo que utiliza la Slice visor por defecto.

2. Acceso Directo

En este modo, el sector está representado por un icono y una etiqueta.

In shortcut mode our slice is represented by the Kotlin drawable

Si hay un encabezado principal asociado con su SliceAction, entonces esto se utilizará como icono de la división. Si no hay ningún icono disponible, Android en su lugar mostrará la acción primaria asociada con la primera fila de la división, que en este caso es nuestro Kotlin dibujable.

Para cambiar el icono que se muestra en el modo de acceso directo, agregue un segundo dibujable a su proyecto y luego actualizar a la siguiente sección del proveedor de slice:

3. Pequeño

Modo pequeño tiene una altura limitada y tampoco mostrará un SliceItem único o una colección limitada de elementos como una sola línea de contenido. Si su slice tiene una cabecera, entonces esto será mostrado, que es exactamente lo que está sucediendo con nuestro slice.

In small mode our slice is represented by a title and a subtitle

Cambiar el título o el subtítulo afecta el contenido que se muestra en modo pequeño.

Si el slice no contiene un encabezado, entonces primera fila del slice se mostrará en su lugar.

Reducir Código, Con Slice Builders KTX

Una vez que haya aprendido cómo implementar una nueva característica, el siguiente paso es aprender a entregar los mismos resultados, con menos código.

KTX Android es una colección de módulos de extensiones que optimizan la plataforma Android para Kotlin. Módulo de corte constructores KTX de KTX Android envuelve el patrón builder en un DSL de Kotlin-friendly que le ayudará a crear tus rebanadas de una manera más concisa, legible. Para empezar con Slice Builders KTX, vuelva a colocar la siguiente dependencia:

Con:

Luego puede modificar su método de createSlice para usar este DSL. Por ejemplo, aquí es una simple slice que muestra un título y un subtítulo:

Con el DSL, esto se convierte:

Conclusión

En este artículo, tenemos alguna experiencia práctica con la característica de slice prometedores de Android. Hemos visto como crear un slice simple que puede proporcionar acceso directo a cualquier parte de la aplicación, antes de pasar a crear slices más complejos consisten en elementos finales, imágenes, texto adicional y varios SliceActions.

Usted puede aprender más sobre slices en la documentación oficial de Android.

Advertisement
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.