「Mac畅玩鸿蒙与硬件26」UI互动应用篇3 - 倒计时和提醒功能实现

本篇将带领你实现一个倒计时和提醒功能的应用,用户可以设置倒计时时间并开始计时。当倒计时结束时,应用会显示提醒。该项目涉及时间控制、状态管理和用户交互,是学习鸿蒙应用开发的绝佳实践项目。


关键词
  • UI互动应用
  • 倒计时器
  • 状态管理
  • 用户交互

一、功能说明

在这个倒计时应用中,用户可以设置倒计时的初始时间,点击按钮启动倒计时,并在倒计时结束时收到提醒。用户还可以暂停和重置倒计时,并恢复到初始设置的时间。


二、所需组件
  • @Entry@Component 装饰器
  • Text 组件用于显示倒计时
  • Button 组件用于用户交互
  • TextInput 组件用于用户输入倒计时初始时间
  • setIntervalclearInterval 方法用于时间控制
项目结构
  • 项目名称CountdownApp
  • 自定义组件名称CountdownPage
  • 代码文件CountdownPage.etsIndex.ets

三、代码实现
typescript 复制代码
// CountdownPage.ets
@Component
export struct CountdownPage {
  @State timeLeft: number = 0; // 剩余时间
  @State initialTime: number = 0; // 初始时间
  @State isRunning: boolean = false; // 倒计时状态
  private intervalId: number | null = null; // 定时器 ID

  build() {
    Column({ space: 20 }) {
      Row() {
        Text("倒计时:")
          .fontSize(25)
          .fontWeight(FontWeight.Bold);
        Text(this.formatTime(this.timeLeft))
          .fontSize(25)
          .fontColor(Color.Red);
      }

      // 输入初始时间
      TextInput({ placeholder: "设置倒计时时间(秒)" })
        .type(InputType.Number)
        .onChange((value: string) => {
          if (!this.isRunning) {
            this.initialTime = parseInt(value) || 0;
            this.timeLeft = this.initialTime; // 更新剩余时间
          }
        });

      // 按钮交互行
      Row({ space: 20 }) {
        Button(this.isRunning ? '暂停' : '开始')
          .onClick(() => {
            if (this.isRunning) {
              this.stopCountdown();
            } else {
              this.startCountdown();
            }
          });

        Button('重置')
          .onClick(() => {
            this.resetCountdown();
          });
      }
      .justifyContent(FlexAlign.Center);

      // 提示倒计时结束
      if (this.timeLeft === 0 && this.isRunning) {
        Text("时间到!")
          .fontSize(30)
          .fontColor(Color.Green)
          .fontWeight(FontWeight.Bold);
      }
    }
    .padding(20)
    .height('100%')
    .width('100%')
    .alignItems(HorizontalAlign.Center);
  }

  private startCountdown() {
    if (this.timeLeft > 0) {
      this.isRunning = true;
      this.intervalId = setInterval(() => {
        if (this.timeLeft > 1) {
          this.timeLeft -= 1;
        } else {
          this.stopCountdown();
        }
      }, 1000);
    }
  }

  private stopCountdown() {
    this.isRunning = false;
    if (this.intervalId !== null) {
      clearInterval(this.intervalId);
      this.intervalId = null;
    }
  }

  private resetCountdown() {
    this.stopCountdown();
    this.timeLeft = this.initialTime; // 将倒计时重置为初始时间
  }

  private formatTime(time: number): string {
    return `${Math.floor(time / 60).toString().padStart(2, '0')}:${(time % 60).toString().padStart(2, '0')}`;
  }
}
typescript 复制代码
// Index.ets
import { CountdownPage } from './CountdownPage'

@Entry
@Component
struct Index {
  build() {
    Column() {
      CountdownPage() // 调用自定义组件
    }
    .padding(20) // 设置页面内边距
  }
}

效果示例 :用户输入时间后点击"开始"按钮,倒计时开始;点击"暂停"按钮暂停倒计时;点击"重置"按钮时倒计时恢复到初始设置的时间。


四、代码解读
  • TextInput()
    用于用户输入倒计时的初始时间。输入值会同时更新 initialTimetimeLeft
  • setInterval()clearInterval()
    setInterval() 用于每秒更新 timeLeft,实现倒计时;clearInterval() 用于暂停或重置倒计时。
  • resetCountdown()
    timeLeft 重置为 initialTime,确保倒计时恢复到用户设置的初始值。

五、相关知识点

小结

本篇教程通过实现倒计时和提醒功能,展示了如何在鸿蒙中使用状态管理和时间控制来实现动态更新和用户交互。掌握这些技能后,你将能够更灵活地开发时间管理相关的应用。


下一篇预告

在下一篇「UI互动应用篇4 - 猫与灯的互动应用」中,我们将探索一个有趣的项目,展示如何结合状态和动态图片实现更丰富的用户互动体验。


上一篇: 「Mac畅玩鸿蒙与硬件25」UI互动应用篇2 - 计时器应用实现
下一篇: 「Mac畅玩鸿蒙与硬件27」UI互动应用篇4 - 猫与灯的互动应用

相关推荐
m0_748245921 小时前
HarmonyOS Next 实现登录注册页面(ARKTS) 并使用Springboot作为后端提供接口
spring boot·华为·harmonyos
程序媛-北北10 小时前
配置Allure环境变量【macOS版】
macos·allure
程思扬10 小时前
Android笔记: 实现点击事件透传到底部
android·前端·windows·经验分享·笔记·科技·ui
专注VB编程开发20年11 小时前
.NET Core封装Activex Dll,向COM公开.NET Core组件
数据库·ui·.netcore·dll·com·activex
__Benco12 小时前
openharmony应用开发快速入门
harmonyos
万少12 小时前
HarmonyOS Next 端云一体化(3)
前端·harmonyos·客户端
塞尔维亚大汉12 小时前
OpenHarmony(鸿蒙南向开发)——小型系统芯片移植指南(二)
操作系统·harmonyos
程序猿阿伟13 小时前
《鸿蒙Next旅游应用:人工智能赋能个性化与智能导览新体验》
人工智能·harmonyos·旅游
Jackson@ML13 小时前
2025最新版IntelliJ IDEA for Mac安装使用指南
java·macos·intellij-idea
丁总学Java13 小时前
在 macOS 上,用命令行连接 MySQL(/usr/local/mysql/bin/mysql -u root -p)
数据库·mysql·macos