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

HarmonyOS 6 ArkTS ImageAnimator 组件使用文档

文章目录核心 API1. 关键属性2. 动画状态 AnimationStatus3. 生命周期回调4. 控制按钮功能完整代码功能说明总结核心 API1. 关键属性属性名作用.images([])设置动画帧传入图片资源数组.duration()设置动画总时长单位毫秒.state()设置/获取动画状态初始、运行、暂停、停止.reverse()设置是否反向播放.iterations()循环次数-1无限循环0指定次数.fillMode()动画结束后显示模式2. 动画状态AnimationStatus状态含义Initial初始状态Running播放中Paused暂停停留在当前帧Stopped停止回到第一帧3. 生命周期回调回调触发时机onStart动画开始onPause动画暂停onRepeat动画重复一次onCancel动画被取消onFinish动画播放完成4. 控制按钮功能start开始播放pause暂停在当前画面stop停止并回到第一帧reverse切换正放/倒放once播放一次infinite无限循环完整代码// xxx.ets Entry Component struct ImageAnimatorExample { State state: AnimationStatus AnimationStatus.Initial; State reverse: boolean false; State iterations: number 1; build() { Column({ space: 10 }) { ImageAnimator() .images([ { // $r(app.media.img1)需要替换为开发者所需的图像资源文件。 src: $r(app.media.start) }, { // $r(app.media.img2)需要替换为开发者所需的图像资源文件。 src: $r(app.media.startIcon) }, { // $r(app.media.img3)需要替换为开发者所需的图像资源文件。 src: $r(app.media.foreground) }, { // $r(app.media.img4)需要替换为开发者所需的图像资源文件。 src: $r(app.media.gif) } ]) .duration(4000) .state(this.state) .reverse(this.reverse) .fillMode(FillMode.None) .iterations(this.iterations) .width(340) .height(240) .margin({ top: 100 }) .onStart(() { console.info(Start) }) .onPause(() { console.info(Pause) }) .onRepeat(() { console.info(Repeat) }) .onCancel(() { console.info(Cancel) }) .onFinish(() { console.info(Finish) this.state AnimationStatus.Stopped }) Row() { Button(start).width(100).padding(5).onClick(() { this.state AnimationStatus.Running }).margin(5) Button(pause).width(100).padding(5).onClick(() { this.state AnimationStatus.Paused // 显示当前帧图片 }).margin(5) Button(stop).width(100).padding(5).onClick(() { this.state AnimationStatus.Stopped // 显示动画的起始帧图片 }).margin(5) } Row() { Button(reverse).width(100).padding(5).onClick(() { this.reverse !this.reverse }).margin(5) Button(once).width(100).padding(5).onClick(() { this.iterations 1 }).margin(5) Button(infinite).width(100).padding(5).onClick(() { this.iterations -1 // 无限循环播放 }).margin(5) } }.width(100%).height(100%) } }运行效果如图点击start按钮开始轮播图片功能说明播放start动画从当前位置开始按顺序播放。暂停pause动画停在当前帧画面不动。停止stop动画终止并回到第一帧。反向播放reverse点击切换正放/倒放可实时切换。播放一次once动画播放一轮后自动停止。无限循环infinite动画无限播放直到手动暂停/停止。总结ImageAnimator只能使用本地资源不支持网络图片。帧图片使用$r(app.media.xxx)加载。动画控制通过修改state实现。支持正向、反向、循环、无限播放。提供完整生命周期回调便于状态同步。如果这篇文章对你有帮助欢迎点赞、收藏、关注你的支持是持续创作的动力

相关文章:

HarmonyOS 6 ArkTS ImageAnimator 组件使用文档

文章目录核心 API1. 关键属性2. 动画状态 AnimationStatus3. 生命周期回调4. 控制按钮功能完整代码功能说明总结核心 API 1. 关键属性 属性名作用.images([])设置动画帧,传入图片资源数组.duration()设置动画总时长(单位:毫秒).…...

终极解决方案:如何在MSVC环境下实现fmtlib的零警告构建

终极解决方案:如何在MSVC环境下实现fmtlib的零警告构建 【免费下载链接】fmt A modern formatting library 项目地址: https://gitcode.com/GitHub_Trending/fm/fmt fmtlib作为一款现代格式化库,在C开发中被广泛应用。然而在MSVC环境下构建时&…...

虚拟机磁盘 IOPS 不够用 / 占用过高?ESXi 两种调整限制的实用教程

在 ESXi 虚拟化环境中,虚拟机的磁盘 IOPS(每秒输入 / 输出操作数)直接影响业务响应速度 —— 部分 VM 因 IOPS 过高抢占资源,会导致其他虚拟机卡顿;而关键业务 VM 可能因 IOPS 限制不足,出现数据读写缓慢。…...

ALOS PALSAR的L波段SAR到底强在哪?从灾害监测到地形测绘的实战应用解析

ALOS PALSAR的L波段SAR技术优势与行业应用深度解析 当洪水淹没村庄、山体发生毫米级位移或森林碳储量需要精准测算时,传统光学遥感往往受制于云层遮挡和时间分辨率。这时,搭载L波段合成孔径雷达的ALOS PALSAR卫星便展现出独特价值——它不仅能穿透云雨实…...

别再只会用sinfo了!Slurm节点状态全解析(从alloc到drain,附排查脚本)

深度解析Slurm节点状态:从基础诊断到高效运维实战 在HPC集群管理中,Slurm作为最常用的作业调度系统,其节点状态监控直接影响着运维效率和资源利用率。许多管理员习惯使用sinfo命令快速查看节点概况,但当遇到作业排队异常或节点故障…...

Qt GraphicsView性能优化实战:当你的场景里有上万个Item时该怎么办?

Qt GraphicsView性能优化实战:海量Item场景下的高效渲染策略 在开发GIS地图编辑器、股票K线分析系统或大规模网络拓扑工具时,我们常常需要处理包含数万个图形项(Item)的复杂场景。当这些场景在标准GraphicsView实现中变得卡顿不流…...

OpenHarmony4.1 源码编译HAP实战:从环境配置到Launcher构建

1. 环境准备:搭建OpenHarmony4.1编译基础 第一次接触OpenHarmony源码编译时,我被复杂的依赖关系搞得晕头转向。后来发现,其实只要抓住几个关键点,环境配置就能事半功倍。官方推荐的Ubuntu 20.04 LTS确实是最稳妥的选择&#xff0c…...

Android Studio开发实战(六)———TableLayout表格布局与FrameLayout帧布局的进阶应用与场景解析

1. TableLayout表格布局的实战进阶技巧 TableLayout是Android中用于实现表格化排版的经典布局方案。很多开发者认为它只能做简单的行列展示,其实通过属性组合和嵌套技巧,完全可以实现复杂的数据表格界面。我在电商类App开发中就经常用它来构建商品参数对…...

多用户环境下的eCapture权限管控:从风险到解决方案

多用户环境下的eCapture权限管控:从风险到解决方案 【免费下载链接】ecapture Capturing SSL/TLS plaintext without a CA certificate using eBPF. Supported on Linux/Android kernels for amd64/arm64. 项目地址: https://gitcode.com/GitHub_Trending/ec/ecap…...

LinkStar H28K旅行路由器评测与OpenWrt配置指南

1. LinkStar H28K旅行路由器开箱与硬件解析初次拿到LinkStar H28K时,这个仅比信用卡略大的金属外壳设备很难让人联想到它是一台全功能路由器。整机采用铝合金材质打造,尺寸控制在55.265.1522.6mm的迷你体积,重量仅120克左右,完全可…...

别再手动改PRN了!LabVIEW调用ZebraDesigner 3 API实现GX420d标签动态打印

别再手动改PRN了!LabVIEW调用ZebraDesigner 3 API实现GX420d标签动态打印 在工业自动化领域,标签打印是产线测试工位不可或缺的环节。传统基于PRN文件替换的方式虽然简单,但面对频繁变更的打印需求时,往往显得笨拙且难以维护。想…...

3步掌握B站评论爬虫:如何轻松获取完整视频评论数据?

3步掌握B站评论爬虫:如何轻松获取完整视频评论数据? 【免费下载链接】BilibiliCommentScraper B站视频评论爬虫 Bilibili完整爬取评论数据,包括一级评论、二级评论、昵称、用户ID、发布时间、点赞数 项目地址: https://gitcode.com/gh_mirr…...

Qt:真正的门槛不是入门,而是维护

很多人第一次写 Qt 项目,感觉还挺顺:拖几个控件,连几个信号槽,按钮一按,界面动了,数据也刷出来了。那一刻很容易产生一种错觉:Qt 也没那么难嘛。 真正让人难受的,往往不是第一个版本…...

ESP32-S3固件烧录总失败?先别急着换芯片,检查这5个硬件条件(附排查清单)

ESP32-S3固件烧录失败?硬件工程师的5步精准排查法 当你面对一块毫无反应的ESP32-S3开发板,电脑屏幕上不断弹出"等待上电同步"的提示,那种挫败感每个硬件开发者都深有体会。但别急着把芯片判死刑——根据我的工程经验,90…...

别再只用原始IoU了!手把手教你用GIOU、DIOU、CIOU优化YOLOv5/v8的检测框回归

目标检测进阶:用GIOU、DIOU、CIOU优化YOLO检测框的实战指南 在目标检测任务中,边界框回归的精度直接影响模型性能。许多工程师发现,即使使用YOLOv5/v8这样的先进框架,在自定义数据集上仍会遇到检测框定位不准、收敛速度慢的问题。…...

告别find命令卡顿!为ARM路由器打造超轻量fd静态链接版本

告别find命令卡顿!为ARM路由器打造超轻量fd静态链接版本 【免费下载链接】fd A simple, fast and user-friendly alternative to find 项目地址: https://gitcode.com/GitHub_Trending/fd/fd 在嵌入式设备如ARM架构路由器上使用传统find命令时,你…...

WarcraftHelper终极技术解决方案:如何让传统游戏在现代系统上完美运行

WarcraftHelper终极技术解决方案:如何让传统游戏在现代系统上完美运行 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper WarcraftHelper是一…...

人IgE His标签蛋白如何助力肿瘤免疫疗法创新?

一、过敏反应与肿瘤免疫有何内在关联?过敏反应是机体免疫系统对花粉、海鲜、尘螨等环境抗原产生的过度防卫现象,临床表现为打喷嚏、皮疹甚至呼吸困难等症状。这一现象的免疫学基础在于肥大细胞的快速应答机制。作为免疫系统中的“哨兵”,肥大…...

ANSYS Mesh网格质量深度解读:除了Skewness,这些指标(Orthogonal Quality, Aspect Ratio)到底怎么看?

ANSYS Mesh网格质量深度解析:从指标解读到实战优化 在CFD仿真中,网格质量往往决定了计算结果的可靠性和收敛效率。许多工程师虽然能够生成看似完整的网格,却对质量报告中的各项指标感到困惑——Orthogonal Quality达到多少才算合格&#xff1…...

终极指南:从Go 1.24到1.25,etcd分布式存储的性能飞跃与实践技巧

终极指南:从Go 1.24到1.25,etcd分布式存储的性能飞跃与实践技巧 【免费下载链接】etcd Distributed reliable key-value store for the most critical data of a distributed system 项目地址: https://gitcode.com/GitHub_Trending/et/etcd etcd…...

Unity里也能直接放PPT?用Aspose.Slides插件实现PPT加载与分页展示(附打包报错解决方案)

Unity3D中高效集成PPT展示功能的工程实践 在教育培训、产品演示和虚拟现实项目中,经常需要将现有的PPT内容无缝嵌入到Unity应用中。传统方案往往要求开发者重新制作所有幻灯片内容为Unity支持的格式,耗时耗力且难以维护更新。本文将介绍一种基于Aspose.S…...

如何在5分钟内制作专业级AI换脸视频:roop-unleashed终极指南

如何在5分钟内制作专业级AI换脸视频:roop-unleashed终极指南 【免费下载链接】roop-unleashed Evolved Fork of roop with Web Server and lots of additions 项目地址: https://gitcode.com/gh_mirrors/ro/roop-unleashed 你是否想过,只需点击几…...

解决Linux蓝牙音频连接疑难杂症:BlueZ 5.50与PulseAudio 12.2常见报错分析与修复指南

Linux蓝牙音频深度排障指南:从协议栈原理到实战修复 当你满心欢喜地戴上蓝牙耳机,准备在Linux系统上享受音乐时,却发现设备明明显示已连接却死活不出声——这种挫败感我太熟悉了。作为经历过数十种蓝牙音频故障的老兵,我将在本文分…...

H5考试场景下腾讯云人脸核身全流程实战

1. 为什么在线考试需要人脸核身? 在线考试作弊一直是教育行业头疼的问题。去年我参与过一个公务员考试系统的开发,监考老师反馈说抓到过有人替考——考生A注册账号,实际考试时却让成绩更好的考生B来操作电脑。这种作弊手段在传统考场很容易识…...

如何永久保存微信聊天记录?这款开源工具让你真正掌握自己的数字记忆

如何永久保存微信聊天记录?这款开源工具让你真正掌握自己的数字记忆 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Tren…...

怎样在Windows电脑上高效安装APK应用:轻量级安卓应用安装器完全指南

怎样在Windows电脑上高效安装APK应用:轻量级安卓应用安装器完全指南 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 想在Windows电脑上直接运行安卓应用却不…...

2026年04月23日最热门的开源项目(Github)

根据本期榜单的分析,我们可以得出以下几点结论: 1. 项目类型和语言分布 项目类型:列表中的项目主要集中在人工智能、代码生成和优化、数据处理等领域。其中,以支持Claude Code的项目(如andrej-karpathy-skills和supe…...

3分钟掌握SRWE:免费窗口分辨率自定义终极指南

3分钟掌握SRWE:免费窗口分辨率自定义终极指南 【免费下载链接】SRWE Simple Runtime Window Editor 项目地址: https://gitcode.com/gh_mirrors/sr/SRWE Simple Runtime Window Editor(SRWE)是一款轻量级开源窗口分辨率工具&#xff0…...

虚拟现实的触觉延伸:vJoy如何重新定义数字世界的物理边界

虚拟现实的触觉延伸:vJoy如何重新定义数字世界的物理边界 【免费下载链接】vJoy Virtual Joystick 项目地址: https://gitcode.com/gh_mirrors/vj/vJoy 在数字与现实的交汇处,我们常常感受到一种奇妙的断裂——当我们的手指在键盘上飞舞&#xff…...

别再只列清单了!用CoCode开发云+WBS,手把手教你搞定敏捷迭代任务分解

敏捷迭代任务分解实战:用CoCode开发云WBS打造高效开发流程 在敏捷开发团队中,最常听到的抱怨莫过于"任务拆解太模糊"或"进度跟踪全靠猜"。传统Scrum板上的便利贴海洋和永无止境的每日站会,往往掩盖了任务分解不彻底的本质…...