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

「Mac畅玩鸿蒙与硬件31」UI互动应用篇8 - 自定义评分星级组件

本篇将带你实现一个自定义评分星级组件,用户可以通过点击星星进行评分,并实时显示评分结果。为了让界面更具吸引力,我们还将添加一只小猫图片作为评分的背景装饰。

在这里插入图片描述


关键词
  • UI互动应用
  • 评分系统
  • 自定义星级组件
  • 状态管理
  • 用户交互

一、功能说明

该自定义评分星级组件允许用户点击星星进行评分,评分范围从 1 到 5 星。点击星星时,页面会更新显示当前评分。同时,界面上添加了一只可爱的猫咪图片来增添趣味性。


二、所需组件
  • @Entry@Component 装饰器
  • ColumnRow 布局组件
  • Image 组件用于显示猫咪图片
  • Text 组件用于显示评分结果
  • Button 组件用于用户交互
  • @State 修饰符用于状态管理
项目结构
  • 项目名称StarRatingApp
  • 自定义组件名称StarRatingPage
  • 代码文件StarRatingPage.etsIndex.ets

三、代码实现
// 文件名:StarRatingPage.ets

// 定义评分页面组件
@Component
export struct StarRatingPage {
  @State currentRating: number = 0; // 当前评分
  maxRating: number[] = [1, 2, 3, 4, 5]; // 评分的最大星级数

  // 构建页面布局和组件
  build() {
    Column({ space: 20 }) { // 创建垂直布局容器,子组件间距为 20
      // 显示猫咪图片
      Image($r('app.media.cat'))
        .width('30%')
        .height('67%')
        .margin({ bottom: 20 })
        .alignSelf(ItemAlign.Center);

      // 显示评分标题
      Text('请给猫咪评分:')
        .fontSize(24)
        .fontWeight(FontWeight.Bold)
        .alignSelf(ItemAlign.Center);

      // 评分星星组件
      Row({ space: 10 }) {
        ForEach(this.maxRating, (star: number) => {
          Button(this.currentRating >= star ? '★' : '☆') // 根据评分状态显示实心或空心星星
            .fontSize(30)
            .onClick(() => {
              this.setRating(star); // 点击星星时更新评分
            })
            .backgroundColor(Color.Transparent) // 背景透明
            .fontColor(this.currentRating >= star ? Color.Yellow : Color.Gray); // 设置选中与未选中颜色
        });
      }
      .justifyContent(FlexAlign.Center);

      // 显示当前评分结果
      Text(`评分: ${this.currentRating} / ${this.maxRating.length}`)
        .fontSize(20)
        .margin({ top: 20 })
        .alignSelf(ItemAlign.Center);
    }
    .padding(20)
    .width('100%')
    .height('100%')
    .alignItems(HorizontalAlign.Center);
  }

  // 更新评分的方法
  private setRating(rating: number) {
    this.currentRating = rating; // 设置当前评分
  }
}
// 文件名:Index.ets

// 导入评分页面组件
import { StarRatingPage } from './StarRatingPage'

// 定义应用入口组件
@Entry
@Component
struct Index {
  build() {
    Column() {
      StarRatingPage() // 引用评分页面组件
    }
    .padding(20) // 设置页面内边距
  }
}

效果示例:用户点击星星即可评分,选中的星星会变为黄色,未选中的星星保持灰色。屏幕上会显示猫咪图片,评分体验更具趣味性。

在这里插入图片描述


四、代码解读
  • @State currentRating
    保存当前的评分值,点击星星时更新评分并触发 UI 重绘。
  • Button 组件
    用于实现星星图标的点击操作,点击时根据评分状态显示实心或空心星星。
  • setRating() 方法
    通过点击星星更新当前评分并实时反馈。

五、优化建议
  1. 添加评分重置功能:可在界面中加入“重置评分”按钮,让用户能重新选择评分。
  2. 增加动画效果:为星星点击添加轻微的缩放或颜色过渡效果,提升用户体验。
  3. 动态猫咪图片:根据评分展示不同状态的猫咪图片,例如高评分显示开心的猫咪,低评分显示伤心的猫咪。

六、相关知识点
  • 「Mac畅玩鸿蒙与硬件11」鸿蒙UI组件篇1 - Text 和 Button 组件详解
  • 「Mac畅玩鸿蒙与硬件12」鸿蒙UI组件篇2 - Image组件的使用

小结

本篇教程通过自定义评分星级组件的实现,演示了如何利用 ButtonText 组件实现评分功能,并通过状态管理动态显示评分结果。添加猫咪图片增强了界面的趣味性,为用户带来更好的交互体验。


下一篇预告

下一篇「UI互动应用篇9 - 番茄钟倒计时应用」将展示如何实现一个番茄钟倒计时应用,用户可以设置专注时间和休息时间的时长。


上一篇: 「Mac畅玩鸿蒙与硬件30」UI互动应用篇7 - 简易计步器
下一篇:「Mac畅玩鸿蒙与硬件32」UI互动应用篇9 - 番茄钟倒计时应用


http://www.kler.cn/a/386852.html

相关文章:

  • Linux高级--3.3.1 C++ spdlog 开源异步日志方案
  • 基于海思soc的智能产品开发(高、中、低soc、以及和fpga的搭配)
  • 华为数据中心CE系列交换机级联M-LAG配置示例
  • MongoDB 学习指南:深入探索非关系型数据库
  • 什么是长连接?Netty如何设置进行长连接?
  • 谷歌宣布没 JavaScript 将无法启动搜索,居然引起了轩然大波
  • Flink on YARN是如何确定TaskManager个数的
  • [spark面试]spark与mapreduce的区别---在DAG方面
  • CI_CD
  • LabVIEW气体检测系统
  • 【Android】组件化开发入门
  • java-web-苍穹外卖-day2-上:测试阶段区分+开发工具区分
  • 在CentOS 7上安装Alist
  • 【elkb】kibana后台删除索引
  • Android OpenGL ES详解——纹理:纹理过滤GL_NEAREST和GL_LINEAR的区别
  • jmeter常用配置元件介绍总结之函数助手
  • Virtual Box 安装 Deepin 系统
  • Ubuntu 修改时区 同步时间
  • lua入门教程:lua函数
  • 【嵌入式开发——Linux操作系统】8进程间通信IPC和内核同步
  • C# 中的 IntPtr
  • C++设计模式结构型模式———代理模式
  • 【计网不挂科】计算机网络期末考试——【选择题&填空题&判断题&简述题】题库(3)
  • Unity插件NodeCanvas之行为树的详细教程
  • python--案例练习:加,幂指数
  • 华为私有接口类型hybrid