【HarmonyOS】ArkUI - 动画

利用属性动画显示动画组件转场动画实现组件动画效果。

一、属性动画

属性动画是通过设置组件的 animation 属性来给组件添加动画,当组件的 width、height、Opacity、backgroundColor、scale、rotate、translate 等属性变更时,可以实现渐变过渡效果。

以 Image 组件为例,给它添加动画,其实就是给它添加 animation 的属性:

Image($r('app.media.app_icon')).position({x: 10, // x轴坐标y: 10  // y轴坐标}).rotate({angle: 0,       // 旋转角度centerX: '50%', // 旋转中心横坐标centerY: '50%'  // 旋转中心纵坐标}).animation({duration: 1000,curve: Curve.EaseInOut})

这时,ArkUI 就能帮我们监控组件的样式变化,我们只需要在与用户互动的事件当中去修改组件的样式,ArkUI 一旦发现组件的样式变化,就会自动填充起始样式和结束样式之间的每一帧画面,从而实现样式变化的渐变过渡效果。所以,一个动画就出来了。

注意:

  1. animation 属性一定要放在需要有动画属性的样式之后。就像上面的实例代码,animation 要放在 position 和 rotate 之后。如果把 animation 放在前面,然后再写 position 和 rotate,那么这俩就不会有任何的变化。

  2. animation 属性不是对所有样式都有效。

animation 可以传递的动画参数:

名称参数类型必填描述
durationnumber设置动画时长。
默认值:1000,单位:毫秒
temponumber动画播放速度。数值越大,速度越快。
默认值:1
curveCurve设置动画曲线。
默认值:Curve.EaseInOut,平滑开始和结束。
delaynumber设置动画延迟执行的时长。
默认值:0,单位:毫秒
iterationsnumber设置播放次数。
默认值:1,取值范围:[-1, +∞)
说明:设置为 -1 时表示无限次播放。
playModePlayMode设置动画播放模式,默认播放完成后重头开始播放。
默认值:PlayMode.Normal
onFinish()=> void状态回调,动画播放完成时触发。

示例代码:

@Entry
@Component
struct Index {@State textX: number = 10@State textY: number = 10build() {Column() {Image($r('app.media.app_icon')).position({x: this.textX,y: this.textY}).rotate({angle: 0,centerX: '50%',centerY: '50%'}).width(40).height(40).animation({duration: 500})Button('按钮').position({x: 10,y: 100}).onClick(() => {this.textX += 20})}}
}

运行效果:
请添加图片描述

二、显示动画

显示动画是通过全局 animationTo 函数来修改组件属性,实现属性变化时的渐变过渡效果。

显示调用 animationTo 函数触发动画:

animateTo({ duration: 1000 }, // 动画参数() => {// 修改组件属性关联的状态变量})

示例代码:

@Entry
@Component
struct Index {@State textX: number = 10@State textY: number = 10build() {Column() {Image($r('app.media.app_icon')).position({x: this.textX,y: this.textY}).rotate({angle: 0,centerX: '50%',centerY: '50%'}).width(40).height(40)Button('按钮').position({x: 10,y: 100}).onClick(() => {animateTo({ duration: 500 },() => {this.textX += 20})})}}
}

三、组件转场动画

组件转场动画是在组件插入或移除时的过渡动画,通过组件的 transition 属性来配置。组件插入可以理解为组件从无到有,也就是一个入场的过程;组件移除可以理解为组件从有到无,也就是一个退场的过程。

语法:

Image($r('app.media.app_icon')).transition({opacity: 0,rotate: { angle: -360 },scale: { x: 0, y: 0 }})

动画参数:

参数名称参数类型必填参数描述
typeTransistionType类型,默认包含组件新增和删除。
默认是 ALL
opacitynumber不透明度,为插入时起点和删除时终点的值。
默认值:1,取值范围:[0, 1]
translate{
  x?: number或string,
  y?: number或string,
  z?: number或string
}
平移效果,为插入时起点和删除时终点的值。
-x: 横向的平移距离。
-y: 纵向的平移距离。
-z: 竖向的平移距离。
scale{
  x?: number,
  y?: number,
   z?: number,
  centerX?: number或string,
  centerY?: number或string
}
缩放效果,为插入时起点和删除时终点的值。
-x: 横向放大倍数(或缩小比例)。
-y: 纵向放大倍数(或缩小比例)。
-z: 当前为二维显示,该参数无效。
-centerX、centerY 指缩放中心点,centerX和centerY默认值是"50%"。
-中心点为0时,默认的是组件的左上角。
rotate{
  x?: number,
  y?: number,
  z?: number,
  angle: number或string,
  centerX?: number或string,
  centerY?: number或string
}
旋转效果:
angle 是旋转角度,其它参数与 scale 类似。

注意:transition 要结合 animateTo 去使用。

示例代码:

@Entry
@Component
struct Index {@State isBegin: boolean = falsebuild() {Column() {if (this.isBegin) {Image($r('app.media.app_icon')).position({x: 10,y: 10}).width(100).height(100).transition({type: TransitionType.Insert,opacity: 0,translate: { x: -100 }})}Button('按钮').position({x: 10,y: 200}).onClick(() => {animateTo({ duration: 1000 },() => {this.isBegin = true})})}}
}

运行效果:
请添加图片描述

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

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

相关文章

AI Kimi:帮助教师做好试卷命题

原文:https://www.toutiao.com/article/7353661304307778083/?log_fromcfd0a50014034_1712243146922 最近,Kimichat工具很火。这款软件不仅仅是一个聊天和阅读工具,还是一个强大的教学辅助工具。作为一位教师,尝试使用Kimichat&…

101. 对称二叉树及同类题

101. 对称二叉树 力扣题目链接(opens new window) 给定一个二叉树,检查它是否是镜像对称的。 递归 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNo…

开源推荐榜【Pear Admin Flask 用python来创建后台管理系统】

最新技术高效快速开发,前后端分离模式,开箱即用。 核心模块包括:用户、角色、职位、组织机构、菜单、字典、日志、多应用管理、文件管理、定时任务等功能。 代码量少、学习简单、功能强大、轻量级、易扩展,轻松开发从现在开始&…

一个线程池的理解

最近看到一个线程池,写的实在太好,于是想深入理解一下。原始代码出处:GitHub - Ahajha/CTPL: Modern and efficient C Thread Pool Library 由于平时的工程一般只支持到C11,而拿到的代码应该是在C20下才能编译通过,因此也做了一些…

第二十三章 Git

一、Git Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。 Git 与常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版…

MIT6.828实验:Xv6 and Unix utilities

2023MIT6.828 lab-1 官方地址 一、sleep 实验内容 调用sleep(系统调用)编写用户级别程序能暂停特定时常的系统滴答程序保存在user/sleep.c 实验过程 xv6的参数传递 查看官方文档提示的文件中,多采用如下定义: int main(in…

【网站项目】三省学堂-学习辅助系统

🙊作者简介:拥有多年开发工作经验,分享技术代码帮助学生学习,独立完成自己的项目或者毕业设计。 代码可以私聊博主获取。🌹赠送计算机毕业设计600个选题excel文件,帮助大学选题。赠送开题报告模板&#xff…

Redis中的Sentinel(一)

Sentinel 概述 Sentinel(哨岗、哨兵)是Redis的高可用性(high availability)解决方案:由一个或多个Sentinel实例(instance)组成的Sentinel系统(system)可以监视任意多个主服务器,以及这些主服务器属下的所有从服务器,并在被监视的主服务器进入下线状态时&#xff0…

JAVA毕业设计133—基于Java+Springboot+Vue的网上宠物店商城管理系统(源代码+数据库+12000字论文)

毕设所有选题: https://blog.csdn.net/2303_76227485/article/details/131104075 基于JavaSpringbootVue的网上宠物店商城管理系统(源代码数据库12000字论文)133 一、系统介绍 本项目前后端分离,分为管理员、用户两种角色 1、用户: 注册…

python-基础篇-字符串、列表、元祖、字典-字符串

文章目录 2.3字符串、列表、元祖、字典2.3.1字符串2.3.1.1字符串介绍2.3.1.1.1python中字符串的格式:2.3.1.1.2字符串在内存中的存储方式 2.3.1.2字符串的输入输出2.3.1.2.1字符串输出2.3.1.2.2字符串输入2.3.1.2.3组字符串的方式 2.3.1.3下标和切片2.3.1.3.1下标索…

Android 系统大致启动流程

Android启动流程大体为:BootRom -> BootLoader -> Kernel -> Init -> Zygote -> SystemServer ->Launcher 1、Loader层 1.1、Boot ROM 电源按下,引导芯片代码开始从预定义的地方(固化在ROM)开始执行&#xff0…

Unity入门

Unity入门学习 知识概述: Unity环境搭建 1.Unity引擎是什么 2.软件下载安装 下载最新的长期支持版即可 3.新工程和工程文件夹 Unity界面基础 1.Scene场景和Hierachy层级窗口 练习: 2.Game游戏和Project工程 3.Inspector检查和Console控制台 练习&#…

医疗器械5G智能制造工厂数字孪生可视化平台,推进行业数字化转型

医疗设备5G智能制造工厂数字孪生可视化平台,推进行业数字化转型。在数字化浪潮的推动下,医疗设备行业正迎来一场深刻的变革。5G技术的崛起,智能制造工厂的兴起,以及数字孪生可视化平台的出现,正在共同推动医疗设备行业…

Xshell Plus 详细安装教程以及附带使用图文教程

一、下载 Xshell Plus 6 完成后,请按照下面教程操作 1、下载 Xshell Plus 6 完成后,并解压 zip 包: 2、进入解压后的文件夹后,如果你之前安装了 Xshell, 先点击 !卸载.bat 卸载 xshell, 然后再点击 !绿化.bat; 如果是…

二分答案(砍树,借教室)

二分的两种情况附代码&#xff1a; 二分查找条件&#xff1a;单调&#xff0c;二段性 例题1&#xff1a;P1873 [COCI 2011/2012 #5] EKO / 砍树 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 上代码&#xff1a; #include<bits/stdc.h> using namespace std; const …

校招说明书

3400字的详细说明&#xff0c;介绍了程序员类岗位校招的整体时间节点和招聘流程。还对一些常见的问题进行讨论&#xff0c;例如内推、offer和三方、实习等。 第一章介绍基本的术语&#xff0c;第二章介绍整个校招的重要流程及时间点&#xff0c;然后第三章介绍每次招聘要经过的…

MySql 实战大数据查询-(表分区实现)

一 mysql分区&#xff1a; 分区是将单个表按照某种规则划分成多个子集&#xff0c;每个子集称为一个分区。常见的分区策略包括按照时间范围、范围值、列表等进行分区。 优点&#xff1a; 查询性能更好&#xff0c;涉及分区键的查询&#xff0c;数据库引擎可以只扫描特定分区&…

易宝OA ExecuteQueryForDataSetBinary SQL注入漏洞复现

0x01 产品简介 易宝OA系统是一种专门为企业和机构的日常办公工作提供服务的综合性软件平台,具有信息管理、 流程管理 、知识管理(档案和业务管理)、协同办公等多种功能。 0x02 漏洞概述 易宝OA ExecuteQueryForDataSetBinary 接口处存在SQL注入漏洞,未经身份认证的攻击者…

Word中插入Endnote参考文献时显示乱码

近期在写文章需要插入参考文献&#xff0c;使用Endnote插入时显示乱码&#xff0c;如下图所示&#xff1a; 文章末尾显示{ADDIN EN REFILIST } 解决方法 在网上找了诸多方法尝试也没有解决&#xff0c;最终找到一篇博客介绍了一种方法&#xff1a; word选项—高级&#xff1…

openGauss学习笔记-256 openGauss性能调优-使用Plan Hint进行调优-优化器GUC参数的Hint

文章目录 openGauss学习笔记-256 openGauss性能调优-使用Plan Hint进行调优-优化器GUC参数的Hint256.1 功能描述256.2 语法格式256.3 参数说明 openGauss学习笔记-256 openGauss性能调优-使用Plan Hint进行调优-优化器GUC参数的Hint 256.1 功能描述 设置本次查询执行内生效的…