科技 > 电脑产品 > 交换机

鸿蒙开发之相对布局、倒计时TextTimer示例代码

4人参与 2026-01-31 交换机

一、relativecontainers

通过子组件之间的相对关系或子组件与父组件(__container__)的相对关系来布局,需结合 alignrules 方法和 id 属性实现。

基础用法步骤

  1. 给子组件设置唯一 id:用于作为其他组件的 “锚点”。
  2. 通过 alignrules 定义对齐规则:每个规则包含 anchor(锚点组件的 id,或容器 __container__)和 align(对齐方式)。

对齐规则的属性与取值

alignrules 支持以下属性(用于定义组件在垂直方向水平方向的对齐逻辑):

方向属性名对齐方式取值(verticalalign/horizontalalign)说明
垂直方向toptop/center/bottom组件的顶部、垂直中心、底部与锚点的对应位置对齐
垂直方向centertop/center/bottom同上(center 是垂直方向的 “中心对齐” 属性,命名容易混淆,需注意)
水平方向leftstart/center/end组件的左边缘、水平中心、右边缘与锚点的对应位置对齐(start 对应左,end 对应右)
水平方向middlestart/center/end

同上(middle 是水平方向的 “中心对齐” 属性)

使用

//组件居中显示
 
relativecontainer() {
  text("居中组件")
    .width(100)
    .height(100)
    .alignrules({
      center: {anchor: "__container__", align: verticalalign.center}, // 垂直居中
      middle: {anchor: "__container__", align: horizontalalign.center} // 水平居中
    })
}
//组件相对排列
 
relativecontainer() {
  text("组件a")
    .width(100)
    .height(100)
    .backgroundcolor(color.red)
    .id("a")
  text("组件b")
    .width(100)
    .height(100)
    .backgroundcolor(color.blue)
    .alignrules({
      top: {anchor: "a", align: verticalalign.bottom}, // 组件b的顶部对齐组件a的底部
      left: {anchor: "a", align: horizontalalign.end}  // 组件b的左边缘对齐组件a的右边缘
    })
}

注意事项

  1. id 必须唯一:同一 relativecontainer 内的所有子组件 id 不能重复。
  2. 避免循环依赖:如果组件 a 的锚点是组件 b,组件 b 的锚点又是组件 a,会导致布局计算失败。

二、倒计时texttimer

通过文本显示计时信息并控制其计时器状态的组件。

名称类型只读可选说明
iscountdownboolean

倒计时开关。值为true时,计时器开启倒计时,例如从30秒 ~ 0秒。值为false时,计时器开始计时,例如从0秒 ~ 30秒。

默认值:false

countnumber

计时器时间(iscountdown为true时生效),单位为毫秒。最长不超过86400000毫秒(24小时)。 0<count<86400000时,count值为计时器初始值。否则,使用默认值为计时器初始值。

默认值:60000

controller

texttimercontroller

texttimer控制器。

format属性

设置自定义格式,需要至少包含一个hh、mm、ss、ss

参数名类型必填说明
valuestring

自定义格式。

默认值:'hh:mm:ss.ss'

ontimer事件

ontimer(event: (utc: number, elapsedtime: number) => void)

时间文本发生变化时触发该事件。锁屏状态和应用后台状态下不会触发该事件。

参数名类型必填说明
utcnumberlinux时间戳,即自1970年1月1日起经过的时间,单位为设置格式的最小单位。
elapsedtimenumber计时器经过的时间,单位为设置格式的最小单位。

texttimercontroller

texttimer组件的控制器,用于控制文本计时器。一个texttimer组件仅支持绑定一个控制器,组件创建完成后相关指令才能被调用。

导入对象

texttimercontroller: texttimercontroller = new texttimercontroller();

使用

@entry
@component
struct time {
  texttimercontroller: texttimercontroller = new texttimercontroller();
 
  onpageshow(): void {
    this.texttimercontroller.start()
 
  }
 
  @state countdown: boolean = true
 
  build() {
    column() {
      texttimer({ count: 5000, controller: this.texttimercontroller, iscountdown: this.countdown })
        .format('ss')
        .fontsize(25)
        .ontimer(
          (utc: number, passtime) => {
            if (passtime == 5) {
              this.getuicontext().getrouter().pushurl({ url: "pages/relativecontainer" })
            }
          }
        )
    }.width('100%')
  }
}

总结

到此这篇关于鸿蒙开发之相对布局、倒计时texttimer的文章就介绍到这了,更多相关鸿蒙相对布局、倒计时texttimer内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

Clawdbot(Moltbot)保姆级安装教程

02-01

老主机焕芯配置! 振华LEADEX BD 1000W ATX3.1金牌电源测评

07-12

百盛高能XG1000电源测评: 轻松带动RTX5090

06-26

浏览器插件cursor实现自动注册、续杯的详细过程

06-25

高颜值白金牌电源竟不到1元1W! 猎金部落Fire系列F10白金全模组电源评测

06-24

MESH网孔透风设计+体积小于初代! 先马趣造3手提式小机箱测评

06-24

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论