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

2024-08-24 19:52

本文主要是介绍【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%')}
}

这篇关于【HarmonyOS NEXT星河版开发实战】灯泡定时开关的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103450

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Python实战之屏幕录制功能的实现

《Python实战之屏幕录制功能的实现》屏幕录制,即屏幕捕获,是指将计算机屏幕上的活动记录下来,生成视频文件,本文主要为大家介绍了如何使用Python实现这一功能,希望对大家有所帮助... 目录屏幕录制原理图像捕获音频捕获编码压缩输出保存完整的屏幕录制工具高级功能实时预览增加水印多平台支持屏幕录制原理屏幕

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

基于Python开发批量提取Excel图片的小工具

《基于Python开发批量提取Excel图片的小工具》这篇文章主要为大家详细介绍了如何使用Python中的openpyxl库开发一个小工具,可以实现批量提取Excel图片,有需要的小伙伴可以参考一下... 目前有一个需求,就是批量读取当前目录下所有文件夹里的Excel文件,去获取出Excel文件中的图片,并