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

HarmonyOS 6 Progress组件设置定制内容区使用文档

文章目录功能概述核心 API1. 接口定义2. 关键类型完整示例代码结构与功能1. 自定义修饰器类MyProgressModifier2. 自定义内容构建器myProgress3. 页面组件Index核心特性1. 进度联动2. 样式定制3. 状态感知4. 完全替换原生内容总结功能概述contentModifier是 HarmonyOS 6 Progress 组件提供的内容定制接口用于完全自定义进度条内部展示区域。可通过该接口替换进度条默认显示内容实现自定义文本展示自定义图标/图形进度联动的动态样式多元素组合布局核心 API1. 接口定义contentModifier(modifier:ContentModifierProgressConfiguration):Progress2. 关键类型ContentModifier内容修饰器基类用于定义自定义内容ProgressConfiguration进度条配置信息包含value当前进度值total总进度值enabled进度条是否可用contentModifier绑定的修饰器实例完整示例// xxx.ets class MyProgressModifier implements ContentModifierProgressConfiguration { color: ResourceColor Color.White; constructor(color: ResourceColor) { this.color color; } applyContent(): WrappedBuilder[ProgressConfiguration] { return wrapBuilder(myProgress); } } Builder function myProgress(config: ProgressConfiguration) { Column({ space: 30 }) { Text(当前进度 config.value / config.total).fontSize(20) Row() { Flex({ justifyContent: FlexAlign.SpaceBetween }) { Path() .width(30%) .height(30%) .commands(M108 0 L141 70 L218 78.3 L162 131 L175 205 L108 170 L41.2 205 L55 131 L1 78 L75 68 L108 0 Z) .fill(config.enabled config.value 1 ? (config.contentModifier as MyProgressModifier).color : Color.White) .stroke(Color.Black) .strokeWidth(3) Path() .width(30%) .height(30%) .commands(M108 0 L141 70 L218 78.3 L162 131 L175 205 L108 170 L41.2 205 L55 131 L1 78 L75 68 L108 0 Z) .fill(config.enabled config.value 2 ? (config.contentModifier as MyProgressModifier).color : Color.White) .stroke(Color.Black) .strokeWidth(3) Path() .width(30%) .height(30%) .commands(M108 0 L141 70 L218 78.3 L162 131 L175 205 L108 170 L41.2 205 L55 131 L1 78 L75 68 L108 0 Z) .fill(config.enabled config.value 3 ? (config.contentModifier as MyProgressModifier).color : Color.White) .stroke(Color.Black) .strokeWidth(3) }.width(100%) } }.margin({ bottom: 100 }) } Entry Component struct Index { State currentValue: number 0; modifier new MyProgressModifier(rgb(39, 135, 217)); State myModifier: (MyProgressModifier | undefined) this.modifier; build() { Column() { Progress({ value: this.currentValue, total: 3, type: ProgressType.Ring }).contentModifier(this.modifier) Button(Progress).onClick(() { if (this.currentValue 3) { this.currentValue 1; } }).width(30%) Button(Progress--).onClick(() { if (this.currentValue 0) { this.currentValue - 1; } }).width(30%).margin(10) }.width(100%).height(100%) } }运行效果如图当点击Process–按钮代码结构与功能1. 自定义修饰器类MyProgressModifier实现ContentModifierProgressConfiguration接口支持传入自定义颜色参数通过applyContent()返回自定义 UI 构建器2. 自定义内容构建器myProgress接收ProgressConfiguration进度配置显示当前进度文本config.value / config.total绘制3 个星形 Path 图标根据进度值动态变色进度 ≥1 / ≥2 / ≥3 时分别点亮对应星星3. 页面组件Index维护进度值currentValue0~3创建修饰器实例并传入自定义颜色环形进度条绑定contentModifier提供 /- 按钮控制进度核心特性1. 进度联动通过config.value可直接获取当前进度实现内容随进度自动更新。2. 样式定制可在修饰器中自定义文本、颜色、字体图形、图标、路径布局、间距、对齐3. 状态感知可通过config.enabled判断进度条是否可用实现可用/不可用状态切换。4. 完全替换原生内容使用contentModifier后原生百分比文本自动隐藏完全展示自定义内容。总结仅支持带内容区的进度条主要为ProgressType.Ring环形必须实现接口修饰器必须实现ContentModifierProgressConfiguration构建器参数必传Builder必须接收ProgressConfiguration参数类型强转使用修饰器自定义属性需as强转为自定义类自动刷新进度值变化时自定义内容会自动刷新如果这篇文章对你有帮助欢迎点赞、收藏、关注你的支持是持续创作的动力

相关文章:

HarmonyOS 6 Progress组件设置定制内容区使用文档

文章目录 功能概述核心 API1. 接口定义2. 关键类型 完整示例代码结构与功能1. 自定义修饰器类:MyProgressModifier2. 自定义内容构建器:myProgress3. 页面组件:Index 核心特性1. 进度联动2. 样式定制3. 状态感知4. 完全替换原生内容 总结 功能…...

SpringBoot+Vue项目里,我是这样用双Token让用户‘无感’登录的(附完整代码)

SpringBootVue双Token无感登录实战:从原理到优雅实现 在前后端分离架构中,用户认证是个绕不开的话题。想象一下这样的场景:你正在填写一个复杂的表单,突然系统弹出"登录已过期"的提示,所有未保存的数据瞬间消…...

PetaPoco映射器自定义指南:从标准映射到约定映射

PetaPoco映射器自定义指南:从标准映射到约定映射 【免费下载链接】PetaPoco Official PetaPoco, A tiny ORM-ish thing for your POCOs 项目地址: https://gitcode.com/gh_mirrors/pet/PetaPoco PetaPoco作为一款轻量级ORM工具,其核心功能在于将数…...

Anaconda新手必看:找不到.condarc文件?别慌,用这3种方法轻松搞定

Anaconda配置指南:从零构建你的.condarc文件 刚接触Anaconda的开发者常常会在配置环节遇到一个典型问题——系统提示找不到.condarc文件。这个看似简单的配置文件实际上掌控着包下载源、环境存储路径等关键参数。不同于网上常见的命令罗列式教程,我们将通…...

互联网大厂Java求职者面试:从核心语言到微服务的全景探讨

互联网大厂Java求职者面试:从核心语言到微服务的全景探讨在互联网大厂的Java开发岗位面试中,候选人燕双非与面试官进行了一场精彩的对话。面试官严肃而专业,而燕双非则以幽默风趣的方式应对各种技术问题。以下是他们的对话记录:第…...

NSudo编译构建全流程:从源码到可执行文件的完整教程

NSudo编译构建全流程:从源码到可执行文件的完整教程 【免费下载链接】NSudo [Deprecated, work in progress alternative: https://github.com/M2Team/NanaRun] Series of System Administration Tools 项目地址: https://gitcode.com/gh_mirrors/ns/NSudo N…...

Java的模块导出与开放包在反射访问权限中的精细控制

Java模块化与反射访问的权限博弈 自Java 9引入模块系统(JPMS)以来,开发者获得了更精细的代码封装能力,但模块导出与开放包的机制也深刻影响了反射的访问权限。这种设计既强化了安全性,又带来了新的挑战。本文将深入探…...

统信UOS/麒麟KYLINOS系统盘快满了?别慌,用这6个命令快速定位是哪个硬盘分区在‘吃’空间

统信UOS/麒麟KYLINOS系统盘空间告急?6步精准定位"空间吞噬者" 当系统弹出"磁盘空间不足"的红色警告时,大多数用户的反应往往是手足无措——尤其是面对国产操作系统的命令行界面时。统信UOS和麒麟KYLINOS作为国内主流Linux发行版&…...

PL-2303驱动在Windows 10上总是单向通信?3种方法让老旧串口设备重获新生

PL-2303驱动在Windows 10上总是单向通信?3种方法让老旧串口设备重获新生 【免费下载链接】pl2303-win10 Windows 10 driver for end-of-life PL-2303 chipsets. 项目地址: https://gitcode.com/gh_mirrors/pl/pl2303-win10 还在为那些"年迈"的PL-2…...

.NET 9跨平台边缘部署实战手册(ARM64/Windows IoT/Linux RT全栈适配大揭秘)

更多请点击: https://intelliparadigm.com 第一章:.NET 9跨平台边缘部署全景概览 .NET 9 正式引入原生 AOT(Ahead-of-Time)编译的生产级支持与轻量级容器运行时优化,显著降低边缘设备资源占用。其跨平台能力已覆盖 Li…...

RTranslator模型快速部署终极指南:5分钟搞定1.2GB离线翻译模型

RTranslator模型快速部署终极指南:5分钟搞定1.2GB离线翻译模型 【免费下载链接】RTranslator Open source real-time translation app for Android that runs locally 项目地址: https://gitcode.com/GitHub_Trending/rt/RTranslator 还在为RTranslator首次启…...

Cursor Free VIP终极指南:三步解决Cursor AI试用限制,永久免费使用Pro功能

Cursor Free VIP终极指南:三步解决Cursor AI试用限制,永久免费使用Pro功能 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pr…...

如何轻松实现Windows和Office永久激活:KMS_VL_ALL_AIO的5个实用技巧

如何轻松实现Windows和Office永久激活:KMS_VL_ALL_AIO的5个实用技巧 【免费下载链接】KMS_VL_ALL_AIO Smart Activation Script 项目地址: https://gitcode.com/gh_mirrors/km/KMS_VL_ALL_AIO 还在为Windows系统激活提示而烦恼?Office突然变成只读…...

如何用WeChatMsg将微信聊天记录变成你的数字记忆宝库?

如何用WeChatMsg将微信聊天记录变成你的数字记忆宝库? 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeCha…...

Firefly边缘AI计算机解析:BM1684X架构与32TOPS算力

1. 边缘AI计算设备解析:Firefly EC-A1684JD4 FD与EC-A1684XJD4 FD在边缘计算和AI推理领域,算力与能效的平衡一直是开发者面临的挑战。Firefly近期推出的EC-A1684JD4 FD和EC-A1684XJD4 FD两款边缘AI嵌入式计算机,基于SOPHON BM1684/BM1684X Ar…...

从TAGE到TAGE-SC-L:一篇看懂现代CPU分支预测器的演进史

从TAGE到TAGE-SC-L:现代CPU分支预测器的技术进化论 在处理器设计的微观世界里,分支预测器如同一位隐形的指挥家,它的每一次判断都直接影响着指令流水线的演奏效率。当现代CPU的主频提升遭遇物理极限,架构师们将目光转向了如何让每…...

终极FlexSlider教程:如何快速创建响应式轮播展示

终极FlexSlider教程:如何快速创建响应式轮播展示 【免费下载链接】FlexSlider An awesome, fully responsive jQuery slider plugin 项目地址: https://gitcode.com/gh_mirrors/fl/FlexSlider FlexSlider是一款功能强大的jQuery轮播插件,能够帮助…...

在macOS上运行Windows软件的终极指南:Whisky让苹果电脑也能畅玩Windows应用

在macOS上运行Windows软件的终极指南:Whisky让苹果电脑也能畅玩Windows应用 【免费下载链接】Whisky A modern Wine wrapper for macOS built with SwiftUI 项目地址: https://gitcode.com/gh_mirrors/wh/Whisky 想在Mac电脑上运行Windows专属的软件和游戏吗…...

ORAN前传延迟实战:手把手教你用eCPRI单向测量搞定T12/T34(含Python模拟脚本)

ORAN前传延迟实战:eCPRI单向测量T12/T34的工程指南与Python模拟 1. 理解ORAN前传延迟的核心挑战 在ORAN架构中,前传网络的延迟管理直接关系到空口同步性能。当O-DU与O-RU之间的传输延迟超出设计范围时,轻则导致吞吐量下降,重则引发…...

朋友圈广告投放异常:IP数据接口提供3个思路+1份清单

微信广告对IP的检测已从“单维度标记”升级为“多维画像风控”,代理IP/数据中心IP被标记的主因是IP属性与请求行为不匹配。本文通过一个真实踩坑案例,给出3个排查思路和1份检查清单,核心在于使用IP数据接口提前验证IP属性,从而减少…...

m4s-converter:5秒完成B站缓存视频无损转换的终极解决方案

m4s-converter:5秒完成B站缓存视频无损转换的终极解决方案 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否曾经为B站视频突然下…...

抖音批量下载器终极指南:如何高效下载视频、音乐和图集的完整解决方案

抖音批量下载器终极指南:如何高效下载视频、音乐和图集的完整解决方案 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser…...

模拟消息队列的消费逻辑-Java

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程​​​​​https://www.captainai.net/troubleshooter 这是一个生产级消息队列消费逻辑模拟,重点突出&am…...

终极NVS别名系统详解:简化Node.js版本管理的5个实用技巧

终极NVS别名系统详解:简化Node.js版本管理的5个实用技巧 【免费下载链接】nvs Node Version Switcher - A cross-platform tool for switching between versions and forks of Node.js 项目地址: https://gitcode.com/gh_mirrors/nv/nvs Node Version Switch…...

PySpark数据处理:精准去重与排序

在数据处理过程中,如何高效地从大量记录中筛选出最新的信息,是每个数据工程师常遇到的问题。今天我们来探讨一个具体的例子,展示如何利用PySpark的窗口函数来实现数据的精准去重和排序。 问题背景 假设我们有一份数据表格,包含了用户ID、日期和访问网站的信息,表格如下:…...

破解工业数据孤岛:DB-GPT与OPC UA的智能融合方案

破解工业数据孤岛:DB-GPT与OPC UA的智能融合方案 【免费下载链接】DB-GPT open-source agentic AI data assistant for the next generation of AI Data products. 项目地址: https://gitcode.com/GitHub_Trending/db/DB-GPT 在工业4.0时代,数据…...

为什么92%的C#团队不敢在生产环境启用拦截器?——基于217家企业的AOP成熟度评估报告(含可执行检查清单)

更多请点击: https://intelliparadigm.com 第一章:C# 13 拦截器的工业级定位与认知误区 C# 13 引入的拦截器(Interceptors)并非传统意义上运行时动态织入的 AOP 工具,而是一种**编译期源码重写机制**,其核…...

从MSTAR到SARDet-100K:20个主流SAR数据集下载、标注格式与实战选型指南(2025版)

SAR目标检测数据集实战选型指南:从数据特性到工程落地(2025版) 当第一次打开HRSID数据集的标注文件时,我被COCO格式里密密麻麻的polygon坐标震撼了——这艘300像素长的货轮被精确勾勒出每一个船舷弧度。而隔壁实验室的博士却对着S…...

从USB到SATA:手把手拆解PCH芯片如何管理你的电脑外设(以Intel 400系列为例)

从USB到SATA:拆解Intel 400系列PCH芯片的外设管理架构 当你在电脑上插入U盘拷贝文件时,数据究竟经历了怎样的旅程?这个看似简单的操作背后,是Intel平台控制器中枢(PCH)在默默协调着USB控制器、SATA控制器和…...

libdxfrw实战指南:打破AutoCAD文件格式壁垒的C++解决方案

libdxfrw实战指南:打破AutoCAD文件格式壁垒的C解决方案 【免费下载链接】libdxfrw C library to read and write DXF/DWG files 项目地址: https://gitcode.com/gh_mirrors/li/libdxfrw 还在为CAD文件格式转换而头疼吗?libdxfrw作为一个强大的DXF…...