Android Compose 实现View中的帧动画功能

本文介绍如何在Android Compose中使用rememberInfiniteTransition创建InfiniteTransition实例,以实现无限循环播放一组图片的帧动画效果。通过animatedValue API结合Int.VectorConverter进行索引控制,设置初始值、目标值、动画时间和重复模式。
摘要由CSDN通过智能技术生成

前言:

最近有个需求(当值如果为true时)要无限循环的播放一组图片,类似传统View的帧动画。
实现这个动画有两个方案:1、设计师做成动画。2、设计师给我们一组图片让我们动画实现。
为了简单就选择了后者,但是Compose没有提供直接的Api,幸运的是可以使用 rememberInfiniteTransition 创建 InfiniteTransition 实例来实现无限循环
InfiniteTransition 有三个添加子动画Api 分别是:animateColor、animatedFloat 或 animatedValue
animateColor 只能用着Color 类型;
animatedFloat 只能用着Float类型;
animatedValue是个泛型。 因为我的图片显示想根据索引去显示,需要用Int类型,所以选择animatedValue。
initialValue = 1//初始值要显示的索引 1
targetValue = 4 //总共要显示的张数 ( < 目标值)
typeConverter = Int.VectorConverter //转换器 这里用的Int的类型 所以填Int.VectorConverter
animationSpec = infiniteRepeatable( // 定动画规范
animation = tween(2000//动画时间(快慢), easing = LinearEasing //匀速),
repeatMode = RepeatMode.Restart//重复方式
)

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值