当前位置: 首页 > news >正文

【HarmonyOS NEXT星河版开发实战】灯泡定时开关

个人主页→VON

收录专栏→鸿蒙综合案例开发​​​​​

代码及其图片资源会发布于gitee上面(已发布)

所有与鸿蒙开发有关的知识点都会在gitee上面进行发布

gitee地址icon-default.png?t=N7T8https://gitee.com/wang-xin-jie234

目录

 前言

界面功能介绍

界面构建思路

头部

 中间

底部

代码讲解

知识点概述

全套源代码


 前言

该案例是一个小型的娱乐项目,主要是定时器的应用。功能并不是很强大,只是简单图片的变化。有兴趣的小伙伴们可以根据界面效果自己进行实现。

界面功能介绍

头部有倒计时的数字,此案例是以三秒举例,当点击开关时开始计时,同时灯泡会变成红色,等倒计时结束后灯泡会重新变暗。 

界面构建思路

头部

 由于整体的UI界面较为简洁,所以就不做过多的赘述了。逻辑部分可以根据注释来慢慢琢磨,主要是对定时器组件的应用。

 中间

中间部分主要是通过条件语句对灯泡的颜色进行改变,灯泡初始时的颜色为灰色,当点击底部按钮的时候会变成红色,表示灯泡亮起时的颜色。 

底部

 

底部主要是通过一个按钮来控制灯泡的状态,当点击按钮的时候不仅灯泡的状态会改变,计时器也会启动来倒计时。 

代码讲解

定义组件

@Entry
@Component
struct Index {

 定义状态变量

// 初始灯泡状态,false表示灯泡关闭,true表示灯泡打开
@State isOpen: boolean = false
// 控制器,用于控制计时器
TimeController: TextTimerController = new TextTimerController()
// 点击按钮后记录下当前的时间,用于计算灯泡开启的时间
@State time: number = 0

 构建UI

build() {Column() {

 头部文字部分

// 头部文字部分,包含标题和计时器
Column({ space: 20 }) {// 标题文本Text('灯泡定时开关').fontSize(30)// 计时器组件,设置为倒计时模式,倒计时时间为3000毫秒TextTimer({ isCountDown: true, count: 3000, controller: this.TimeController }).fontSize(30).fontWeight(700).format('mm:ss.SS') // 设置计时器显示格式.onTimer((utc: number) => {// 当计时器触发时,检查当前时间与记录时间的差值是否大于3000毫秒if (utc - this.time > 3000) {// 如果超过3000毫秒,关闭灯泡并重置计时器this.isOpen = falsethis.TimeController.reset()}})
}
.width('100%')
.justifyContent(FlexAlign.Center) // 使内容居中对齐
.margin({ top: 20 }) // 设置顶部外边距

 中部灯泡部分

// 中部灯泡部分,根据灯泡状态显示不同的图片
if (this.isOpen === false) {// 如果灯泡关闭,显示关闭状态的图片Image($r('app.media.bulboff')).width('60%').margin({ top: '40%' }) // 设置顶部外边距
} else {// 如果灯泡打开,显示打开状态的图片Image($r('app.media.bulbon')).width('60%').margin({ top: '40%' }) // 设置顶部外边距
}

  底部按钮部分

// 底部按钮部分,用于控制灯泡的开关
Button('开关').margin({ top: '40%' }) // 设置顶部外边距.width('50%').fontWeight(700).fontSize(20).onClick(() => {// 切换灯泡状态this.isOpen = !this.isOpen// 记录当前时间this.time = new Date().getTime()if (this.isOpen) {// 如果灯泡打开,启动计时器this.TimeController.start()} else {// 如果灯泡关闭,重置计时器this.TimeController.reset()}})
}
.width('100%')
.height('100%')

知识点概述

鸿蒙开发中的计时器组件,主要是通过TickTimer组件来实现的。鸿蒙操作系统(HarmonyOS)是华为推出的一款面向全场景的分布式操作系统,旨在通过一个统一的操作平台,实现智能设备间的无缝连接和协同工作。在鸿蒙系统中,为了实现计时器功能,开发者可以利用TickTimer组件。这个组件是Text组件的一个子类,它能够继承并使用Text组件的一系列属性,比如字体大小、颜色等。

鸿蒙开发的计时器组件TickTimer具有丰富的属性和方法。TickTimer组件拥有多个属性,如format和count_down。通过设置这些属性,开发者可以自定义计时器的显示格式以及计时的方向,即正计时或倒计时。此外,TickTimer还提供了开始、暂停、重置等方法,使得计时器的操作更加灵活多样。

TickTimer组件的应用非常广泛,它可以被用于各种需要计时的场景,如运动计时、烹饪计时、学习计时等。例如,在一个健身应用中,可以通过TickTimer组件来帮助用户记录每个运动动作的持续时间。在教育应用中,可以利用TickTimer来设定阅读或学习的时长,帮助使用者管理时间。此外,TickTimer还可以用于游戏开发中,比如计时挑战或解谜游戏中的倒计时环节。

全套源代码

@Entry
@Component
struct Index {// 初始灯泡状态,false表示灯泡关闭,true表示灯泡打开@State isOpen: boolean = false// 控制器,用于控制计时器TimeController: TextTimerController = new TextTimerController()// 点击按钮后记录下当前的时间,用于计算灯泡开启的时间@State time: number = 0build() {Column() {// 头部文字部分,包含标题和计时器Column({ space: 20 }) {// 标题文本Text('灯泡定时开关').fontSize(30)// 计时器组件,设置为倒计时模式,倒计时时间为3000毫秒TextTimer({ isCountDown: true, count: 3000, controller: this.TimeController }).fontSize(30).fontWeight(700).format('mm:ss.SS') // 设置计时器显示格式.onTimer((utc: number) => {// 当计时器触发时,检查当前时间与记录时间的差值是否大于3000毫秒if (utc - this.time > 3000) {// 如果超过3000毫秒,关闭灯泡并重置计时器this.isOpen = falsethis.TimeController.reset()}})}.width('100%').justifyContent(FlexAlign.Center) // 使内容居中对齐.margin({ top: 20 }) // 设置顶部外边距// 中部灯泡部分,根据灯泡状态显示不同的图片if (this.isOpen === false) {// 如果灯泡关闭,显示关闭状态的图片Image($r('app.media.bulboff')).width('60%').margin({ top: '40%' }) // 设置顶部外边距} else {// 如果灯泡打开,显示打开状态的图片Image($r('app.media.bulbon')).width('60%').margin({ top: '40%' }) // 设置顶部外边距}// 底部按钮部分,用于控制灯泡的开关Button('开关').margin({ top: '40%' }) // 设置顶部外边距.width('50%').fontWeight(700).fontSize(20).onClick(() => {// 切换灯泡状态this.isOpen = !this.isOpen// 记录当前时间this.time = new Date().getTime()if (this.isOpen) {// 如果灯泡打开,启动计时器this.TimeController.start()} else {// 如果灯泡关闭,重置计时器this.TimeController.reset()}})}.width('100%').height('100%')}
}

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Unity 图表插件Xcharts的一些坑
  • 【高级IO总结】深度探索高级IO:五种IO模型、高级IO、Select、Poll、Epoll工作模式
  • 信号队列。
  • Ubuntu22.04安装深度学习的GPU环境详细教程(小白图文,显卡驱动、CUDA、cuDNN、PyTorch一步到位)
  • One-Shot Visual Imitation Learning via Meta-Learning
  • python学习之路 - 面向对象编程
  • win10配置adb环境变量
  • Java框架第三课(Spring)超级全
  • SpringBoot集成MybatisPlus
  • Python编程实例-NumPy中的掩码数组用于处理缺失数据
  • C++实现的购物小程序
  • UGUI空白可点击组件,减少重绘
  • OpenLayers3, 设置地图背景
  • Word中设置奇数页的页眉为一级标题内容;偶数页的页眉为文章题目
  • HTML 总结
  • android图片蒙层
  • Docker容器管理
  • isset在php5.6-和php7.0+的一些差异
  • JavaScript 一些 DOM 的知识点
  • JavaScript设计模式与开发实践系列之策略模式
  • laravel with 查询列表限制条数
  • MySQL主从复制读写分离及奇怪的问题
  • Next.js之基础概念(二)
  • Selenium实战教程系列(二)---元素定位
  • Terraform入门 - 3. 变更基础设施
  • ucore操作系统实验笔记 - 重新理解中断
  • 短视频宝贝=慢?阿里巴巴工程师这样秒开短视频
  • 给自己的博客网站加上酷炫的初音未来音乐游戏?
  • 简单数学运算程序(不定期更新)
  • 浅谈Golang中select的用法
  • 写给高年级小学生看的《Bash 指南》
  • 再谈express与koa的对比
  • # 利刃出鞘_Tomcat 核心原理解析(二)
  • ###STL(标准模板库)
  • (2021|NIPS,扩散,无条件分数估计,条件分数估计)无分类器引导扩散
  • (9)目标检测_SSD的原理
  • (八)五种元启发算法(DBO、LO、SWO、COA、LSO、KOA、GRO)求解无人机路径规划MATLAB
  • (层次遍历)104. 二叉树的最大深度
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (剑指Offer)面试题41:和为s的连续正数序列
  • (面试必看!)锁策略
  • (三)mysql_MYSQL(三)
  • (实战篇)如何缓存数据
  • (四)stm32之通信协议
  • (一)VirtualBox安装增强功能
  • (原創) 如何動態建立二維陣列(多維陣列)? (.NET) (C#)
  • (转)平衡树
  • (转)为C# Windows服务添加安装程序
  • ***监测系统的构建(chkrootkit )
  • .360、.halo勒索病毒的最新威胁:如何恢复您的数据?
  • .env.development、.env.production、.env.staging
  • .java 指数平滑_转载:二次指数平滑法求预测值的Java代码
  • .net core 控制台应用程序读取配置文件app.config
  • .NET I/O 学习笔记:对文件和目录进行解压缩操作
  • .net 发送邮件