设置容器属性

您可以定义网格容器配置,以创建可根据不同的屏幕尺寸和内容类型进行调整的灵活布局。本页面介绍了如何执行以下操作:

定义网格

网格由列和行组成。 Grid 可组合项具有 config 参数,该参数接受一个 lambda 来定义 GridConfigurationScope 中的列和行。 以下示例定义了一个包含三行两列的网格,每行和每列都具有在 Dp 中指定的固定大小:

Grid(
    config = {
        repeat(2) {
            column(160.dp)
        }
        repeat(3) {
            row(90.dp)
        }
    }
) {
}

将内容放置在网格中

Grid 会获取 content lambda 中的界面元素,并将它们放置到网格单元中。无论您是否明确定义了行和列,网格都会布局列表项。 默认情况下,Grid 会尝试将界面元素放置在行中的可用网格单元格中;如果无法放置,则会将其放置在下一行中的可用网格单元格中。如果没有空单元格,Grid 会创建新行。

在以下示例中,网格有 6 个网格单元,每个单元都放置了一张卡片(图 1)。 每个网格单元的大小为 160dp x 90dp,因此整个网格的大小为 320dp x 270dp

Grid(
    config = {
        repeat(2) {
            column(160.dp)
        }
        repeat(3) {
            row(90.dp)
        }
    }
) {
    Card1()
    Card2()
    Card3()
    Card4()
    Card5()
    Card6()
}

六张卡片放置在具有三行两列的网格中。
图 1。 六张卡片放置在具有三行两列的网格中。

如需将此默认行为更改为按列填充,请将 flow 属性设置为 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()
}

流函数会更改放置商品的方向。
图 2GridFlow.Row(左侧)和 GridFlow.Column(右侧)。

管理轨道尺寸

行和列统称为网格轨道。您可以使用以下任一方法指定网格轨道的大小:

  • 固定 (Dp):分配特定大小(例如 column(180.dp))。
  • 分数 (Float):分配总可用空间中从 0.0f1.0f 的百分比(例如,row(0.5f) 表示 50%)。
  • 灵活 (Fr):在计算固定轨道和分数轨道后,按比例分配剩余空间。例如,如果两个行的值分别设置为 1.fr3.fr,则后者会获得剩余高度的 75%。
  • 固有:根据轨道内的内容调整轨道大小。如需了解详情,请参阅从本质上确定网格轨道大小

以下示例使用不同的轨道尺寸调整选项来定义行高:

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)")

使用四种主要轨道尺寸调整选项定义的行高。
图 3。 使用 Grid 中的四种主要轨道尺寸调整选项定义的行高。

内在确定网格轨道大小

如果您希望布局适应内容,而不是强制将其放入固定容器中,则可以为 Grid 使用固有尺寸调整。网格轨道大小由以下值确定:

  • GridTrackSize.MaxContent:使用内容的最大固有大小(例如,宽度由不换行的文本块中文字的完整长度决定)。
  • GridTrackSize.MinContent:使用内容的最小固有尺寸(例如,宽度由文本块中最长的单个字词决定)。
  • GridTrackSize.Auto:使用可根据可用空间调整的灵活轨道尺寸。默认情况下,它的行为与 MaxContent 类似,但会缩小并封装其内容以适应父级容器。

以下示例将两段文字并排放置。 第一个文本的列大小由显示文本所需的最小宽度决定,而第二个列宽度取决于文本所需的最大宽度。

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." )
}

列中指定的固有大小。
图 4。 列中指定的固有大小。

设置行间距和列间距

网格轨道设置好大小后,您可以修改网格间距,以调整轨道之间的间距。 您可以使用 columnGap 函数指定列间距,并使用 rowGap 指定行间距。在以下示例中,每行之间有 16dp 的间距,每列之间有 8dp 的间距(图 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()
}

行和列之间的间距。
图 5。 行和列之间的间距。

您还可以使用便捷函数 gap 来定义相同列大小和行大小的间距,以及使用单个函数分别定义列大小和间距大小。以下代码会向网格添加 8dp 间距:

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()
}