「Mac畅玩鸿蒙与硬件41」UI互动应用篇18 - 多滑块联动控制器

简介: 本篇将带你实现一个多滑块联动的控制器应用。用户可以通过拖动多个滑块,动态控制不同参数(如红绿蓝三色值),并实时显示最终结果。我们将以动态颜色调节为例,展示如何结合状态管理和交互逻辑,打造一个高级的滑块控制器应用。

本篇将带你实现一个多滑块联动的控制器应用。用户可以通过拖动多个滑块,动态控制不同参数(如红绿蓝三色值),并实时显示最终结果。我们将以动态颜色调节为例,展示如何结合状态管理和交互逻辑,打造一个高级的滑块控制器应用。

20241201_013405.gif


关键词
  • UI互动应用
  • 自定义滑块
  • 多滑块联动
  • 状态管理
  • 用户交互

一、功能说明

多滑块联动控制器应用允许用户通过调整多个滑块来控制参数,并实时显示结果。本示例以 RGB 三色调节为例,用户可以:

  1. 分别调整红、绿、蓝三个滑块的值。
  2. 实时查看滑块组合后的颜色结果。
  3. 点击按钮重置滑块值。

二、所需组件

  • @Entry@Component 装饰器
  • ColumnRow 布局组件
  • Slider 组件用于滑块交互
  • Text 组件用于显示滑块值和结果提示
  • Button 组件用于重置滑块值
  • @State 修饰符用于状态管理

三、项目结构

  • 项目名称MultiSliderApp
  • 自定义组件名称MultiSliderPageMultiSlider
  • 代码文件MultiSliderPage.etsIndex.etsMultiSlider.ets

四、代码实现

// 文件名:MultiSliderPage.ets
import {
    MultiSlider } from "./MultiSlider";

@Component
export struct MultiSliderPage {
   
  @State colors: number[] = [128, 128, 128]

  build() {
   
    Column({
    space: 20 }) {
   
      // 显示当前颜色结果
      Text(`当前颜色: rgb(${
     this.colors[0]}, ${
     this.colors[1]}, ${
     this.colors[2]})`)
        .fontSize(20)
        .alignSelf(ItemAlign.Center);

      // 显示颜色预览框
      Row() {
   
        Image($r('app.media.cat'))
          .width(85)
          .height(100)
          .borderRadius(5); // 增加猫的圆角效果
      }
      .width('100%')
      .height(120)
      .backgroundColor(this.getRGBColor())
      .borderRadius(10)
      .justifyContent(FlexAlign.Center);

      // 调用颜色滑块组件,直接传递 @State 的值
      MultiSlider({
   
        label: '红色',
        value: this.colors[0], // 传递父组件的值
        color: Color.Red,
        colors: this.colors
      });

      MultiSlider({
   
        label: '绿色',
        value: this.colors[1], // 传递父组件的值
        color: Color.Green,
        colors: this.colors
      });

      MultiSlider({
   
        label: '蓝色',
        value: this.colors[2], // 传递父组件的值
        color: Color.Blue,
        colors: this.colors
      });

      // 重置按钮
      Button('重置')
        .onClick(() => this.resetValues())
        .backgroundColor(Color.Gray)
        .fontColor(Color.White)
        .width('50%')
        .alignSelf(ItemAlign.Center);
    }
    .padding(20)
    .width('100%')
    .height('100%')
    .alignItems(HorizontalAlign.Center);
  }

  // 获取 RGB 颜色字符串
  private getRGBColor(): string {
   
    return `rgb(${
     this.colors[0]}, ${
     this.colors[1]}, ${
     this.colors[2]})`;
  }

  // 重置滑块值
  private resetValues() {
   
    this.colors[0] = 128;
    this.colors[1] = 128;
    this.colors[2] = 128;
  }
}
// 文件名:Index.ets
import {
    MultiSliderPage } from "./MultiSliderPage";  // 引入 MultiSliderPage

@Entry
@Component
export struct Index {
   
  build() {
   
    Column({
    space: 20 }) {
   
      // 这里渲染 MultiSliderPage 组件
      MultiSliderPage();  // 使用 MultiSliderPage 组件
    }
    .padding(20)
    .width('100%')
    .height('100%')
    .alignItems(HorizontalAlign.Center);
  }
}
// 文件名:MultiSlider.ets
@Component
export struct MultiSlider {
   
  @Prop label: string = '';  // 标签
  @Prop value: number = 0;
  @Prop color: Color = Color.White; // 滑块颜色
  @State colors: number[] = [128, 128, 128]

  build() {
   
    Column({
    space: 10 }) {
   
      // 显示标签和当前值
      Text(`${
     this.label}: ${
     this.value}`)
        .fontSize(18)
        .fontWeight(FontWeight.Bold)
        .fontColor(this.color);

      // 滑块组件
      Slider({
   
        min: 0,     // 最小值
        max: 255,   // 最大值
        value: this.value,  // 当前值
      })
        .blockColor(this.color)  // 设置滑块颜色
        .onChange((newValue: number) => {
   
          this.value = newValue;  // 更新 @State 的值
          if (this.color == Color.Red) {
   
            this.colors[0] = newValue
          }
          else if (this.color == Color.Green) {
   
            this.colors[1] = newValue
          }
          else if (this.color == Color.Blue) {
   
            this.colors[2] = newValue
          }
        })
        .width('90%')
        .alignSelf(ItemAlign.Center);
    }
    .margin({
    top: 10 });
  }
}

效果示例:用户可以通过拖动红、绿、蓝三个滑块调整颜色值,动态显示颜色预览,并通过重置按钮恢复初始值。

20241201_013405.gif


五、代码解读

  • 动态滑块联动:通过 @State 分别管理红、绿、蓝三个滑块的值,动态计算 rgb 颜色并更新预览框背景。
  • Slider 组件封装:使用 createSlider 方法简化滑块的创建逻辑,提高代码复用性。
  • 重置功能:点击重置按钮后,通过 resetValues 方法将滑块值重置为初始值。

六、优化建议

  1. 增加色彩渐变背景:为滑块添加渐变背景,帮助用户直观理解颜色值变化。
  2. 保存颜色历史记录:记录用户调整过的颜色值,方便快速恢复或对比。
  3. 支持多种颜色模式:增加 HSL 或 HEX 模式切换,扩展功能适用性。

七、相关知识点


小结

通过多滑块联动控制器的实现,用户可以体验到复杂交互场景中 Slider 组件的高级用法,并学习状态管理与动态界面更新的结合应用。本应用提供了实用的交互功能,是学习鸿蒙 UI 开发的重要案例。


下一篇预告

在下一篇「UI互动应用篇19 - 数字键盘应用」中,我们将探索如何实现一个数字键盘,支持用户输入数字并动态更新显示。


上一篇: 「Mac畅玩鸿蒙与硬件40」UI互动应用篇17 - 照片墙布局

下一篇: 「Mac畅玩鸿蒙与硬件42」UI互动应用篇19 - 数字键盘应用


作者:SoraLuna
链接:https://www.nutpi.net/thread?topicId=343
來源:坚果派
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


目录
相关文章
|
前端开发 安全 开发工具
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
996 90
【11】flutter进行了聊天页面的开发-增加了即时通讯聊天的整体页面和组件-切换-朋友-陌生人-vip开通详细页面-即时通讯sdk准备-直播sdk准备-即时通讯有无UI集成的区别介绍-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草Alex
|
人工智能 自然语言处理 API
用自然语言控制电脑,字节跳动开源 UI-TARS 的桌面版应用!内附详细的安装和配置教程
UI-TARS Desktop 是一款基于视觉语言模型的 GUI 代理应用,支持通过自然语言控制电脑操作,提供跨平台支持、实时反馈和精准的鼠标键盘控制。
5872 17
用自然语言控制电脑,字节跳动开源 UI-TARS 的桌面版应用!内附详细的安装和配置教程
|
UED
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
本篇教程将实现一个模拟火车票查询系统,通过输入条件筛选车次信息,并展示动态筛选结果,学习事件处理、状态管理和界面展示的综合开发技巧。
418 13
「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
本篇教程将实现一个打卡提醒小应用,通过用户输入时间进行提醒设置,并展示实时提醒状态,实现提醒设置和取消等功能。
402 10
「Mac畅玩鸿蒙与硬件53」UI互动应用篇30 - 打卡提醒小应用
|
缓存 Python
mac彻底卸载应用
删除应用 打开访达,找到PyCharm应用,移到废纸篓; 清除残留数据 清理缓存,参数,日志相关配置文件,示例文件名:PyCharm2019.2 打开终端依次执行下列命令 cd ~/Library/Preferences/ rm -rf PyCharm2019.
|
8月前
|
前端开发 安全 测试技术
Postman Mac 版安装终极指南:从下载到流畅运行,一步到位
Postman 是 API 开发与测试的高效工具,支持各类 HTTP 请求调试与团队协作。本文详解 Mac 版下载、安装步骤,助你快速上手。同时推荐一体化 API 协作平台 Apifox,集文档、调试、测试于一体,提升开发效率与团队协同能力。
|
11月前
|
iOS开发 MacOS 索引
在不受支持的 Mac 上安装 macOS Tahoe 26
在不受支持的 Mac 上安装 macOS Tahoe 26
879 0
在不受支持的 Mac 上安装 macOS Tahoe 26
|
Ubuntu Linux Shell
Ubuntu gnome WhiteSur-gtk-theme类mac主题正确安装和卸载方式
通过这个过程,用户不仅可以定制自己的桌面外观,还可以学习到更多关于 Linux 系统管理的知识,从而更好地掌握系统配置和主题管理的技巧。
2363 12
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。