Puedes definir una configuración de contenedor de cuadrícula para crear diseños flexibles que respondan a diferentes tamaños de pantalla y tipos de contenido. En esta página, se describe cómo hacer lo siguiente:
- Definir una cuadrícula: Configurar la estructura básica de filas y columnas
- Colocar elementos en una cuadrícula: Comprender cómo se colocan los elementos en las celdas de la cuadrícula y cómo cambiar la dirección del flujo
- Administrar el tamaño de los recorridos: Usar tamaños fijos, fraccionarios, flexibles e intrínsecos para establecer los tamaños de los recorridos
- Establecer espacios: Administrar los "medianiles" entre filas y columnas
Definir una cuadrícula
Una cuadrícula consta de columnas y filas.
El elemento componible Grid tiene un parámetro config
que acepta una lambda para definir las columnas y las filas
dentro de GridConfigurationScope.
En el siguiente ejemplo, se define una cuadrícula que tiene tres filas y dos columnas,
cada una con un tamaño fijo especificado en Dp:
Grid( config = { repeat(2) { column(160.dp) } repeat(3) { row(90.dp) } } ) { }
Colocar elementos en una cuadrícula
Grid toma los elementos de la IU en la lambda content y los coloca en las celdas de la cuadrícula.
La cuadrícula dispone los elementos, independientemente de si definiste explícitamente las filas y las columnas.
De forma predeterminada, Grid intenta colocar un elemento de la IU en la celda de la cuadrícula disponible en la fila; si no puede, lo coloca en una celda de la cuadrícula disponible en la siguiente fila.
Si no hay celdas vacías, Grid crea una fila nueva.
En el siguiente ejemplo, la cuadrícula tiene seis celdas y coloca una tarjeta en cada una (Figura 1).
Cada celda de la cuadrícula es de 160dp x 90dp, lo que hace que el tamaño total de la cuadrícula sea de 320dp x 270dp.
Grid( config = { repeat(2) { column(160.dp) } repeat(3) { row(90.dp) } } ) { Card1() Card2() Card3() Card4() Card5() Card6() }
Para cambiar este comportamiento predeterminado a un relleno por columna,
establece la propiedad flow en GridFlow.Column.
Grid( config = { repeat(2) { column(160.dp) } repeat(3) { row(90.dp) } gap(8.dp) flow = GridFlow.Column // Grid tries to place items to fill the column }, ) { Card1() Card2() Card3() Card4() Card5() Card6() }
GridFlow.Row (izquierda) y GridFlow.Column (derecha).
Administrar el tamaño de los recorridos
Las filas y las columnas se denominan colectivamente recorrido de la cuadrícula. Puedes especificar el tamaño de un recorrido de la cuadrícula con uno de los siguientes métodos:
- Fijo (
Dp): Asigna un tamaño específico (p.ej.,column(180.dp)). - Fraccionario (
Float): Asigna un porcentaje del espacio disponible total de0.0fa1.0f(p.ej.,row(0.5f)para el 50%). - Flexible (
Fr): Distribuye el espacio restante de forma proporcional después de que se calculan los recorridos fijos y fraccionarios. Por ejemplo, si dos filas se establecen en1.fry3.fr, la última recibe el 75% de la altura restante. - Intrínseco: Dimensiona el recorrido en función del contenido que contiene. Para obtener más información, consulta Determina el tamaño del recorrido de la cuadrícula de forma intrínseca.
En el siguiente ejemplo, se usan las diferentes opciones de tamaño de recorrido para definir las alturas de las filas:
Grid( config = { column(1f) row(100.dp) row(0.2f) row(1.fr) row(GridTrackSize.Auto) }, modifier = Modifier.height(480.dp) ) { PastelRedCard("Fixed(100.dp)")
Grid.
Determina el tamaño del recorrido de la cuadrícula de forma intrínseca
Puedes usar el tamaño intrínseco para un Grid
cuando quieras que el diseño se adapte al contenido,
en lugar de forzarlo a un contenedor fijo.
El tamaño del recorrido de la cuadrícula se determina con los siguientes valores:
GridTrackSize.MaxContent: Usa el tamaño intrínseco máximo del contenido (p.ej., el ancho se determina por la longitud completa del texto en un bloque de texto sin ajuste de línea).GridTrackSize.MinContent: Usa el tamaño intrínseco mínimo del contenido (p.ej., el ancho se determina por la palabra más larga en un bloque de texto).GridTrackSize.Auto: Usa un tamaño flexible para un recorrido que se adapte según el espacio disponible. Se comporta comoMaxContentde forma predeterminada, pero reduce y ajusta su contenido para que quepa dentro del contenedor superior.
En el siguiente ejemplo, se colocan dos textos uno al lado del otro. El tamaño de la columna para el primer texto se determina por el ancho mínimo requerido para mostrar el texto, y el ancho de la segunda columna depende del ancho máximo requerido del texto.
Grid( config = { column(GridTrackSize.MinContent) column(GridTrackSize.MaxContent) row(1.0f) }, modifier = Modifier.width(480.dp) ) { Text("Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras imperdiet." ) Text("Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras imperdiet." ) }
Establecer espacios entre filas y columnas
Una vez que se dimensionan los recorridos de la cuadrícula,
puedes modificar el espacio de la cuadrícula para ajustar el espaciado entre los recorridos.
Puedes especificar el espacio de la columna con la columnGap función,
y el espacio de la fila con rowGap. En el siguiente ejemplo, hay un espacio de 16dp entre cada fila y un espacio de 8dp entre cada columna (Figura 5).
Grid( config = { repeat(2) { column(160.dp) } repeat(3) { row(90.dp) } rowGap(16.dp) columnGap(8.dp) } ) { Card1() Card2() Card3() Card4() Card5() Card6() }
También puedes usar la función de conveniencia gap
para definir espacios del mismo tamaño de columna y fila,
y para definir los tamaños de columna y espacio por separado con una sola función.
El siguiente código agrega espacios de 8dp a la cuadrícula:
Grid( config = { repeat(2) { column(160.dp) } repeat(3) { row(90.dp) } gap(8.dp) // Equivalent to columnGap(8.dp) and rowGap(8.dp) } ) { Card1() Card2() Card3() Card4() Card5() Card6() }