Cuadrícula

Grid es una API de Jetpack Compose que te permite implementar de manera flexible un diseño bidimensional. Con esta API, puedes mostrar elementos en diseños de varias columnas o filas que se adapten al tamaño del contenedor disponible.

Un diseño bidimensional flexible y adaptable con cuadrícula
Figura 1. Un diseño bidimensional flexible y adaptable con Grid.

¿En qué se diferencia Grid de los elementos componibles similares?

Compose ya ofrece componentes similares, como LazyVerticalGrid. Estos componentes son principalmente para la visualización de conjuntos de datos grandes y homogéneos, por ejemplo, para mostrar un catálogo de contenido en una app de transmisión de video. Estos componentes NO están diseñados para el diseño estructural de una pantalla o un componente complejo.

También puedes implementar un diseño bidimensional combinando varios elementos componibles Row y Column. Sin embargo, este enfoque tiene algunas desventajas, como jerarquías profundas y dificultades en la adaptabilidad.

En la siguiente tabla, se proporciona una descripción general de los diseños adecuados para cada API:

Componente Propósito
LazyVerticalGrid, LazyStaggeredGrid, LazyHorizontalGrid Visualización de conjuntos de datos grandes y homogéneos que requieren carga diferida
Row, Column, FlexBox Diseño unidimensional
Grid Diseño bidimensional

Terminología

Familiarízate con la siguiente terminología para comprender cómo funciona Grid.

Línea de cuadrícula

Una cuadrícula se compone de líneas que se ejecutan horizontal y verticalmente. Si tu cuadrícula tiene tres filas, tiene cuatro líneas horizontales, incluida la que está después de la última fila. En la siguiente imagen, cada línea punteada representa una línea de cuadrícula:

La cuadrícula consta de cuatro líneas horizontales y tres líneas verticales.
Figura 2: La cuadrícula consta de cuatro líneas horizontales y tres líneas verticales.

Pista de cuadrícula

Una pista de cuadrícula es el espacio entre dos líneas de cuadrícula. Una pista de fila está entre dos líneas horizontales, y una pista de columna está entre dos líneas verticales. Para definir el tamaño de estas pistas, asígnales un tamaño cuando crees la cuadrícula.

Es un carril de cuadrícula para la primera fila.
Figura 3: Una pista de cuadrícula para la primera fila.

Celda de cuadrícula

Una celda de cuadrícula es la intersección de una pista de fila y una de columna.

Una celda de cuadrícula que es la intersección de la segunda fila y la segunda columna.
Figura 4: Una celda de cuadrícula que es una intersección de la segunda fila y la segunda columna.

Área de cuadrícula

Un área de cuadrícula consta de varias celdas de cuadrícula. Puedes definir un área de cuadrícula haciendo que un elemento abarque varias pistas.

Es un área de cuadrícula que consta de cuatro celdas de cuadrícula.
Figura 5: Un área de cuadrícula que consta de cuatro celdas de cuadrícula.

Espacio de cuadrícula

Un espacio de cuadrícula es el espacio entre las pistas de cuadrícula. No puedes colocar un elemento de la IU en un espacio, pero puedes abarcarlo.

Es un espacio entre la primera y la segunda columna de la cuadrícula.
Figura 6: Un espacio de cuadrícula entre la primera y la segunda columna.