第十四讲_ArkUI网格布局(Grid/GridItem)

1. 网格布局概述

  • 网格布局是由“行”和“列”分割的单元格所组成,是一种自适应布局。
  • ArkUI 提供了 Grid 容器组件和子组件 GridItem,用于构建网格布局。
  • Grid 容器组件默认占满父容器。

2. Grid的使用

2.1 设置网格布局的行列数量与占比

Grid 组件提供了 rowsTemplatecolumnsTemplate 属性用于设置网格布局行列数量与尺寸占比。

@Entry
@Component
struct GridLayout {
   
  build() {
   
    Grid() {
   

    }
    // 垂直方向分成3份,每行占一份
    .rowsTemplate("1fr 1fr 1fr")
    // 水平方向分成4份,第一列占1份,第二列占2份,第三列占1份
    .columnsTemplate("1fr 2fr 1fr")
  }
}

在这里插入图片描述

2.2 设置网格布局的行列间距

Grid 组件通过 rowsGapcolumnsGap 属性设置网格布局的行列间距。

@Entry
@Component
struct GridLayout {
   
  build() {
   
    Grid() {
   

    }
    // 垂直方向分成3份,每行占一份
    .rowsTemplate("1fr 1fr 1fr")
    // 水平方向分成4份,第一列占1份,第二列占2份,第三列占1份
    .columnsTemplate("1fr 2fr 1fr")
    // 行间距
    .rowsGap(10)
    // 列间距
    .columnsGap(10)
  }
}

在这里插入图片描述

3. GridItem的使用

3.1 设置GridItem所占行列数

GridItem 组件通过设置 rowStart(起始行号)、rowEnd(终点行号)、columnStart(起始列号)和 columnEnd(终点列号)属性,表示子组件所占行列数。

@Entry
@Component
struct GridLayout {
   
  build() {
   
    Grid() {
   
      GridItem()
        .rowStart(0)
        .rowEnd(0)
        .columnStart(0)
        .columnEnd(1)
        .backgroundColor(Color.Red)

      GridItem()
        .rowStart(0)
        .rowEnd(1)
        .columnStart(2)
        .columnEnd(1)
        .backgroundColor(Color.Orange)

      GridItem()
        .rowStart(1)
        .rowEnd(2)
        .columnStart(0)
        .columnEnd(0)
        .backgroundColor(Color.Blue)

      GridItem()
        .rowStart(1)
        .rowEnd(1)
        .columnStart(1)
        .columnEnd(1)
        .backgroundColor(Color.Pink
### ArkUI 网格布局实现计算器的方法 在 ArkUI 中,网格布局可以通过 `Grid` 组件实现。这种布局非常适合像计算器这样的界面设计需求,因为可以灵活定义每一行和列的宽度以及高度,并支持跨行或跨列的功能。 #### 1. **基本概念** 网格布局由“行”和“列”组成的单元格构成,能够通过指定项目的所在单元格创建多样化的布局形式[^2]。对于计算器而言,“0”键通常会占据两个列宽,而“=”键则可能跨越多个行高。 #### 2. **实现步骤** 以下是基于 ArkUI网格布局实现计算器的具体方法: - 首先引入必要的组件库并初始化页面。 - 定义一个 `Grid` 容器用于承载所有的按钮控件。 - 设置每行的高度比例与每列的宽度比例以适配不同屏幕尺寸。 - 对于特殊按键(如 “0” 和 “=”),利用 `span` 属性设置它们分别占用多列或多行的空间。 #### 3. **代码示例** 下面是一个简单的 ArkUI 实现计算器 UI 的例子: ```xml <GridLayout columnsTemplate="repeat(4, 1fr)" rowsTemplate="repeat(5, 1fr)"> <!-- 数字键 --> <Button text="7" gridRow="0" gridColumn="0"></Button> <Button text="8" gridRow="0" gridColumn="1"></Button> <Button text="9" gridRow="0" gridColumn="2"></Button> <Button text="4" gridRow="1" gridColumn="0"></Button> <Button text="5" gridRow="1" gridColumn="1"></Button> <Button text="6" gridRow="1" gridColumn="2"></Button> <Button text="1" gridRow="2" gridColumn="0"></Button> <Button text="2" gridRow="2" gridColumn="1"></Button> <Button text="3" gridRow="2" gridColumn="2"></Button> <!-- 特殊处理 '0' 键 跨越两列 --> <Button text="0" gridRow="3" gridColumn="0" columnSpan="2"></Button> <!-- 运算符和其他功能键 --> <Button text="/" gridRow="0" gridColumn="3"></Button> <Button text="*" gridRow="1" gridColumn="3"></Button> <Button text="-" gridRow="2" gridColumn="3"></Button> <Button text="+" gridRow="3" gridColumn="3"></Button> <!-- '=' 按钮跨越最后一整行 --> <Button text="=" gridRow="4" gridColumn="0" columnSpan="4"></Button> </GridLayout> ``` 上述 XML 结构展示了如何使用 Grid 布局来安排标准四则运算计算器上的所有按键位置[^1]。其中特别注意的是 `'0'` 按钮设置了 `columnSpan="2"` 来使其覆盖前两列;`=`, 则设定了 `columnSpan="4"` 占据整个底部区域。 #### 4. **注意事项** 当进行实际开发时需遵循一定的流程确保最终效果满足预期:明确目标设备分辨率下的最佳显示方案;合理分配空间给每一个子项以便获得良好的用户体验;最后测试调整直至达到理想状态[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值