HarmonyOS 通过 animateTo讲解角度动画效果

本文 我们依旧来说动画

这次 我们来说角度

我们先写一个这样的代码模板

typescript 复制代码
@Entry
@Component
struct Index {

  build() {
    Column({space: 30}) {
      Text("修改元素尺寸")
        .fontSize(38)
        .margin({top:188})
      Image("https://img2.baidu.com/it/u=1814561676,2470063876&fm=253&fmt=auto&app=138&f=JPEG?w=750&h=500")
        .width(200)
        .height(150)

      Button("执行").onClick((event: ClickEvent) => {
        animateTo({
          duration: 3000,
          curve: Curve.Linear,
          //delay: 2000,
          iterations: 3,
          playMode: PlayMode.Alternate,
          onFinish: (()=>{
            console.log("动画结束");
          })
        },() => {
        })
      })
  }
    .width('100%')
    .height('100%')
  }
}

这里 我们放了一个 Image 图片组件 里面是个网图地址

然后 我们还是用按钮定义了一个点击事假 里面用了 animateTo 动画 不过目前 没有写动画是要干嘛的

这里 我们就可以在点击事件中修改角度属性

我们先给 Image 组件加上属性rotate

typescript 复制代码
Image("https://img2.baidu.com/it/u=1814561676,2470063876&fm=253&fmt=auto&app=138&f=JPEG?w=750&h=500")
.width(200)
.height(150)
.rotate({
    angle: 30,
})

rotate 就是设置元素旋转的属性

angle 设置中心点偏转的角度 我们给 30

可以看到 我们的图片 中心就转了一个幅度

然后 我们将他打 rotate 改成

typescript 复制代码
.rotate({
	angle: 30,
	x: 1
})

这里 我们给 x 1的意思是 我们要按x轴去偏转

这样 我们图片偏转的角度 明显就变了

x轴 为面对我们这个上下正方向 90度为一个半圆 那么 我们来一个 80度

我们整个图片 也成了快躺平的一个状态

180度 整个圆 它就整个反过来了

我们改成y轴

typescript 复制代码
rotate({
	angle: 40,
	 y: 1
})

然后是 z轴 她就说 我们最开始看到的这个平面旋转的效果

那么 这里其实 我们控制 angle 就OK了

这里还有个点 例如 我们x y z都打开

那 它是三轴都发生旋转

如果你不想让某个轴转 给0就好了

例如

typescript 复制代码
rotate({
    angle: 40,
	x: 0,
	y: 0,
	z: 1
})

这样 就只有为1的z轴转了

代码最上面 我们写一个状态变量 number 数字类型

来控制 angle 角度属性 然后 默认给0

typescript 复制代码
@State rotateAngle:number = 0;

然后 用 rotateAngle 绑定 旋转角度属性

typescript 复制代码
rotate({
	angle: this.rotateAngle,
	 x: 0,
	 y: 0,
	 z: 1
})

然后 我们将 下面 Button按钮的代码修改如下

typescript 复制代码
Button("执行").onClick((event: ClickEvent) => {
	animateTo({
	 duration: 3000,
	 curve: Curve.Linear,
	 //delay: 2000,
	 iterations: 3,
	 playMode: PlayMode.Alternate,
	 onFinish: (()=>{
	   console.log("动画结束");
	 })
	},() => {
	 this.rotateAngle = 180
	})
})

只需要在箭头函数中 修改 rotateAngle 的值 之前的第一参数配置都是一样的

然后 我们点击按钮 整个动画 他就转起来了

相关推荐
脑极体6 分钟前
寻找AI大模型时代的存力破壁人:华为的行与思
人工智能·华为
别说我什么都不会18 分钟前
【仓颉三方库】工具类——zip4cj & zlib4cj
harmonyos
ghjhjjjbjibh4 小时前
AI大模型 —— 国产大模型 —— 华为大模型
人工智能·华为
高木的小天才12 小时前
鸿蒙中的并发线程间通信、线程间通信对象
前端·华为·typescript·harmonyos
脑极体15 小时前
开源鸿蒙,给机器人带来了什么?
华为·机器人·开源·harmonyos
Aqua Cheng.16 小时前
25.4.22华为--算法真题整理(2025年4月22日)
java·算法·leetcode·华为·面试
HarmonyOS_SDK17 小时前
意图框架事件推荐方案,精准匹配用户需求
harmonyos
Tolitres17 小时前
「鸿蒙 NEXT」基于 taskpool 实现自定义 Timer 工具类
harmonyos
城中的雾18 小时前
一键多环境构建——用 Hvigor 玩转 HarmonyOS Next
harmonyos
别说我什么都不会19 小时前
【仓颉三方库】分布式——config-client
harmonyos