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

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

在这里插入图片描述


关键词
  • 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 });}
}

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

在这里插入图片描述


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

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

七、相关知识点
  • 「Mac畅玩鸿蒙与硬件11」鸿蒙 UI 组件篇1 - Text 和 Button 组件详解
  • 「Mac畅玩鸿蒙与硬件13」鸿蒙 UI 组件篇3 - Slider 组件的使用

小结

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


下一篇预告

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


上一篇: 「Mac畅玩鸿蒙与硬件40」UI互动应用篇17 - 照片墙布局
下一篇: 「Mac畅玩鸿蒙与硬件42」UI互动应用篇19 - 数字键盘应用

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


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/483787.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

利用红黑树封装map,和set,实现主要功能

如果不知道红黑树是什么的时候可以去看看这个红黑树 思路 首先我们可以把封装分为两个层面理解,上层代码就是set,和map,底层就是红黑树 就相当于根据红黑树上面套了两个map,set的壳子,像下面这张图一样 对于map和set,map里面存…

汽车网络安全 -- IDPS如何帮助OEM保证车辆全生命周期的信息安全

目录 1.强标的另一层解读 2.什么是IDPS 2.1 IDPS技术要点 2.2 车辆IDPS系统示例 3.车辆纵深防御架构 4.小结 1.强标的另一层解读 在最近发布的国家汽车安全强标《GB 44495》,在7.2节明确提出了12条关于通信安全的要求,分别涉及到车辆与车辆制造商云平台通信、车辆与车辆…

R语言机器学习论文(二):数据准备

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据一、数据描述二、数据预处理(一)修改元素名称(二)剔除无关变量(三)缺失值检查(四)重复值检查(五)异常值检查三、描述性统计(一)连续变量数据情…

java基础语法光速入门

前言 欢迎来到我的博客 个人主页:北岭敲键盘的荒漠猫-CSDN博客 本文整理Java的基础语法部分 适合有编程基础的人快点掌握语法使用 没学过一两门语言的话。。还是不建议看了 极致的浓缩没有一点解释 注释 单行注释 // 多行注释 /**/ 数据类型 布尔型:true false 整型:int,lon…

【Linux】常用命令二

声明:以下内容均学习自《Linux就该这么学》一书。 1、cat 用于查看内容较少的纯文本文件。 参数-n可以显示行号。 2、more 用于查看内容较多的纯文本文件。 它会在最下面使用百分比的形式来提示你已经月读了多少内容,你可以使用空格键或回车键向下翻…

springboot利用easypoi实现简单导出Excel

vue springboot利用easypoi实现简单导出 前言一、easypoi是什么?二、使用步骤 1.传送门2.前端vue3.后端springboot 3.1编写实体类(我这里是dto,也一样)3.2控制层结尾 前言 今天玩了一下springboot利用easypoi实现excel的导出,以前…

合规性要求对漏洞管理策略的影响

讨论漏洞管理中持续面临的挑战,包括确定漏洞的优先级和解决修补延迟问题。 介绍合规性要求以及自动化如何简化漏洞管理流程。 您认为为什么尽管技术不断进步,但优先考虑漏洞和修补延迟等挑战仍然存在? 企业基础设施日益复杂,攻…

【NLP高频面题 - LLM架构篇】旋转位置编码RoPE相对正弦位置编码有哪些优势?

【NLP高频面题 - LLM架构篇】旋转位置编码RoPE相对正弦位置编码有哪些优势? 重要性:⭐⭐⭐ 💯 NLP Github 项目: NLP 项目实践:fasterai/nlp-project-practice 介绍:该仓库围绕着 NLP 任务模型的设计、训练…

STM32 PWM波形详细图解

目录 前言 一 PWM介绍 1.1 PWM简介 1.2 STM32F103 PWM介绍 1.3 时钟周期与占空比 二.引脚映像关系 2.1引脚映像与寄存器 2.2 复用功能映像 三. PWM 配置步骤 3.1相关原理图 3.2配置流程 3.2.1 步骤一二: 3.2.2 步骤三: 3.2.3 步骤四五六七: …

洛谷 B2029:大象喝水 ← 圆柱体体积

【题目来源】https://www.luogu.com.cn/problem/B2029【题目描述】 一只大象口渴了,要喝 20 升水才能解渴,但现在只有一个深 h 厘米,底面半径为 r 厘米的小圆桶 (h 和 r 都是整数)。问大象至少要喝多少桶水才会解渴。 …

使用docker部署GBase8s数据库(jdk安装,docker安装,GBase部署)

jdk安装步骤 1.将压缩包上传到/opt/software 2.解压到/opt/module tar -zxvf jdk-8u212-linux-x64.tar.gz -C /opt/module 3.配置环境变量 3.1 在/etc/profile.d目录下创建my_env.sh sudo touch my_env.sh 3.2在文件中添加内容 sudo vim my_env…

嵌入式 C 编程:const 关键字 —— 打造稳定的常量空间

目录 一、const关键字的基本含义与用法 1.1. 修饰基本数据类型 1.2. 修饰指针 1.3. 修饰数组 1.4. 修饰结构体 二、const关键字在嵌入式编程中的优势 2.1. 提升代码可读性 2.2. 增强代码安全性 2.3. 优化内存使用 2.4. 促进模块化设计 2.5. 支持静态分析和测试 三、…

【k8s】kubelet 的相关证书

在 Kubernetes 集群中,kubelet 使用的证书通常存放在节点上的特定目录。这些证书用于 kubelet 与 API 服务器之间的安全通信。具体的位置可能会根据你的 Kubernetes 安装方式和配置有所不同,下图是我自己环境【通过 kubeadm 安装的集群】中的kubelet的证…

USB 声卡全解析:提升音频体验的得力助手

在当今数字化的时代,音频领域的追求愈发多元。无论是热衷聆听高品质音乐的爱好者,还是在专业音频工作中精雕细琢的人士,亦或是在游戏世界里渴望极致音效沉浸的玩家,都始终在寻觅能让音频体验更上一层楼的妙法。而 USB 声卡&#x…

git查看本地库对应的远端库的地址

git查看本地库对应的远端库的地址 git remote -v 如果想要查看特定的远端库的url地址,可以使用如下命令,其中origin是默认的远端库的名称,可以使用其他远端库的名称 get remote get-url origin

深入解析级联操作与SQL完整性约束异常的解决方法

目录 前言1. 外键约束与级联操作概述1.1 什么是外键约束1.2 级联操作的实际应用场景 2. 错误分析:SQLIntegrityConstraintViolationException2.1 错误场景描述2.2 触发错误的根本原因 3. 解决方法及优化建议3.1 数据库级别的解决方案3.2 应用层的解决方案 4. 友好提…

社区团购中 2+1 链动模式商城小程序的创新融合与发展策略研究

摘要:本文聚焦于社区团购这一新兴零售模式的发展态势,深入探讨 21 链动模式商城小程序与之融合的创新机制与应用策略。通过剖析社区团购的运营模式、优势特点以及发展现状,结合 21 链动模式商城小程序的功能特性,研究二者协同作用…

qt QGraphicsScale详解

1、概述 QGraphicsScale是Qt框架中提供的一个类,它提供了一种简单而灵活的方式在QGraphicsView框架中实现缩放变换。通过设置水平和垂直缩放因子、缩放中心点,可以创建各种缩放效果,提升用户界面的交互性和视觉吸引力。结合QPropertyAnimati…

Narya.ai正在寻找iOS工程师!#Mixlab内推

如果你对AI技术和iOS开发充满热情,这里有一个绝佳的机会加入一家专注于AI应用创新的初创公司。Narya.ai正在招聘iOS工程师,帮助他们开发下一代效率工具,旨在提升用户的日常生活效率与幸福感。 关于Narya.ai: 专注于AI应用层创新&a…

CSS学习记录03

CSS背景 CSS 背景属性用于定义元素的背景效果。 CSS background-color background-color属性指定元素的背景色。 页面的背景色设置如下: body {background-color: lightblue; } 通过CSS,颜色通常由以下方式指定: 有效的颜色名称-比如“…