Establece el comportamiento del contenedor

Para configurar el comportamiento del contenedor FlexBox, crea un bloque FlexBoxConfig y proporciónalo con el parámetro config.

FlexBox(
    config = {
        direction(FlexDirection.Column)
        wrap(FlexWrap.Wrap)
        alignItems(FlexAlignItems.Center)
        alignContent(FlexAlignContent.SpaceAround)
        justifyContent(FlexJustifyContent.Center)
        gap(16.dp)
    }
) { // child items
}

Usa FlexBoxConfig para definir la dirección del diseño, el comportamiento de ajuste, la alineación y los espacios entre los elementos.

Dirección del diseño

La función direction establece el eje principal, que determina la dirección en la que se disponen los elementos. Acepta los siguientes valores:

  • Row (predeterminado): Establece el eje principal como horizontal. En las configuraciones regionales de izquierda a derecha, será de izquierda a derecha, y viceversa en las de derecha a izquierda.
  • RowReverse: Invierte la dirección de Row.
  • Column: Establece el eje principal como vertical, de arriba hacia abajo.
  • ColumnReverse: Invierte la dirección de Column.

Cómo alinear elementos y distribuir espacio adicional

En las siguientes secciones, se describe cómo alinear elementos y distribuir espacio adicional a lo largo de los ejes principal y transversal.

A lo largo del eje principal

Usa justifyContent para distribuir elementos a lo largo del eje principal. En la siguiente tabla, se muestra el comportamiento cuando la dirección es Row.

Ilustración de un eje principal horizontal.

Start

Los elementos se alinean al inicio del eje principal.

Center

Los elementos están alineados al centro del eje principal.

End

Los elementos se alinean al final del eje principal.

SpaceBetween

Elementos distribuidos a lo largo del eje principal con espacio entre ellos.

SpaceAround

Los elementos se distribuyen a lo largo del eje principal con espacio alrededor.

SpaceEvenly

Elementos distribuidos a lo largo del eje principal con espacio uniforme alrededor de ellos.

A lo largo del eje transversal

Usa alignItems para alinear elementos a lo largo del eje transversal dentro de una sola línea. Este comportamiento se puede anular en elementos individuales con el modificador alignSelf.

En las siguientes imágenes, se muestra el comportamiento cuando la dirección es Row:

Ilustración de un eje cruzado vertical. Los elementos se alinean al inicio del eje transversal. Los elementos se alinean al final del eje transversal. Los elementos están alineados al centro del eje transversal. Los elementos se estiran para llenar el eje transversal. Los elementos se alinean a su línea de base a lo largo del eje transversal.

Start

End

Center

Stretch

Baseline

Usa alignContent para alinear las líneas con el eje transversal y distribuir el espacio adicional entre ellas. Esta propiedad solo se aplica cuando hay varias líneas (el ajuste está habilitado). En las siguientes imágenes, se muestra el comportamiento cuando la dirección es Row:

Ilustración de un eje cruzado vertical. Varias líneas de elementos alineadas con el inicio del eje transversal. Varias líneas de elementos alineados al final del eje transversal. Varias líneas de elementos alineados al centro del eje transversal. Varias líneas de elementos se extienden para llenar el eje transversal. Varias líneas de elementos distribuidas a lo largo del eje transversal con espacio entre ellas. Varias líneas de elementos distribuidos a lo largo del eje transversal con espacio alrededor de ellos.

Start

End

Center

Stretch

SpaceBetween

SpaceAround

Cómo unir elementos

El ajuste permite que un contenedor FlexBox se convierta en varias líneas, lo que mueve los elementos que no caben a una nueva fila o columna a lo largo del eje transversal. Configura el comportamiento de ajuste con wrap.

FlexWrap valor

Ejemplo con la dirección Row

NoWrap (predeterminado): Evita que los elementos se ajusten. Los elementos se desbordan si el tamaño principal es insuficiente.

Los elementos de una sola línea desbordan el contenedor porque la función de ajuste está inhabilitada.

Wrap: Cuando no hay suficiente espacio para un elemento (más cualquier brecha), se crea una nueva línea en la dirección del eje transversal. Por ejemplo, si la dirección es Row, se agrega una línea nueva debajo.

Los elementos se ajustan a una nueva línea a continuación porque el ajuste está habilitado.

WrapReverse: Es igual que Wrap, excepto que la línea nueva se agrega en la dirección opuesta al eje transversal. Por ejemplo, si la dirección es Row, se agrega una línea nueva arriba.

Los elementos se ajustan a una nueva línea arriba porque el ajuste inverso está habilitado.

En el siguiente ejemplo, se muestra cómo funciona el algoritmo de ajuste FlexBox. El contenedor FlexBox tiene un tamaño principal de 100dp, con wrap establecido en FlexWrap.Wrap y una brecha de 8dp. Contiene tres elementos con basis 20dp, 40dp y 50dp, respectivamente.

Hay 100dp espacios disponibles en la línea. El hijo 1 es 20dp. Hay espacio, por lo que el hijo 1 se coloca en la fila.

Es el primer elemento colocado en el contenedor FlexBox.
Figura 1: FlexBoxPrimer elemento colocado en el contenedor.

Hay 80dp espacios disponibles en la línea. La brecha es de 8dp. El hijo 2 es 40dp. El espacio requerido es 48dp. Hay espacio, por lo que la brecha y el elemento secundario 2 se colocan en la línea.

Es el primer elemento colocado en el contenedor FlexBox.
Figura 2: Segundo elemento colocado en el contenedor FlexBox después del primer elemento.

Hay 32dp espacios disponibles en la línea. La brecha es de 8dp. El hijo o hija 3 es 50dp. El espacio requerido es 58dp. No hay suficiente espacio en la línea actual, por lo que el hijo 3 se coloca en una línea nueva.

El tercer elemento se coloca en una línea nueva porque no cabe en la primera.
Figura 3: El tercer elemento se coloca en una línea nueva porque no cabe en la primera.

Agregar espacios entre elementos

Agrega espacios entre filas y columnas con rowGap y columnGap. Esto es útil para evitar agregar modificadores de espaciado a los elementos secundarios.

El espacio entre filas agrega espacio vertical entre los elementos. El espacio entre columnas agrega espacio horizontal entre los elementos. Gap agrega espacio horizontal y vertical entre los elementos.

rowGap

Agrega espacio vertical entre elementos y líneas.

columnGap

Agrega espacio horizontal entre elementos y líneas.

gap es una función conveniente que agrega columnGap y rowGap.