Android Compose状态改变动画animateXxxAsState怎么使用


今天小编给大家分享一下AndroidCompose状态改变动画animateXxxAsState怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。在 Compose 中提供了一系列动画 API,其中有一类 API 跟属性动画非常类似,它就是animateXxxAsState,我翻译成状态改变动画,其中Xxx对应的是DpFloatIntSizeOffsetRectIntOffsetIntSizeColor数据类型,即当状态改变时触发对应数据类型的值的发生改变,从而执行数据从当前值到目标值变化的动画。对应 Api 如图:接下来就看看这些 Api 到底是如何使用的。我们首先以animateDpAsState为例来看一下animateXxxAsState动画到底如何使用。Dp是 Compose 提供的一个封装数据类型,作用跟在传统 Android 开发中 xml 使用的dp单位是一样的,是与屏幕像素密度相关的抽象单位。Compose 中为其提供了基础数据类型的扩展,可以直接使用数值.dp进行使用,如:10.dp12.5.dp等。在 Compose 中跟长度相关的参数类型基本上都是Dp,如宽高、圆角、间距等等。animateDpAsState的定义如下:参数说明:targetValue:目标值animationSpec:动画规格finishedListener:动画完成监听返回值是一个State对象,即当其内部 value 值发生改变时会触发 Compose 的重组,从而刷新界面。前面说了animateXxxAsState跟属性动画类似,但是好像不对呀,这里参数只有一个targetValue即目标值,熟悉属性动画的都知道,属性动画的数值参数是一个可变参数,当为 1 个的时候,初始值为属性当前值,目标值为传入参数值,多个参数时初始值为第一个参数值,那这里只有一个targetValue参数是不是也是初始值是从组件中获取呢?我们来试试,创建一个 Box 通过改变其左边距实现向右移动的动画:因为需要对左边距进行改变,所以将 padding 的 start 提取为 startPadding 变量,如上面的代码,但是这样的话那初始值就是animateDpAsState传入的值,也就是这里的 10.dp ,先运行一下看看是不是这样:运行效果确实是这样,那怎么实现动画效果呢?是修改 startPadding 的值么?我们给 Box 添加一个点击事件修改 startPadding 的值看看:这样写编辑器直接报错了,错误信息如下:说 val 变量不能重新赋值,是因为 startPadding 变量定义成了 val 所以不能修改么?并不是,因为我们重新赋值的不是 startPadding 变量,而是其内部的 value,而 startPadding 是 State 类型,State 内部的 value 是 val 的,定义如下:所以并不能通过重新赋值修改animateDpAsState创建的 State 的 value 值,那么怎么修改这个值让其产生动画呢?前面说了 animateXxxAsState 是依赖状态改变而产生值的变化,所以实际上我们这里还需要定义一个额外的状态变量,targetValue 参数根据这个状态传入不同的值,修改上面代码如下:修改点如下:使用 mutableStateOf 创建 moveToRight 变量,内部值为 Boolean 类型,即 MutableState,因为是在 Compose 函数中使用,需要用 remember 函数包裹,防止重组时重复创建修改 animateDpAsState 传入参数的固定值为根据 moveToRight 传入,即if (moveToRight) 100.dp else 10.dp修改点击事件处理,修改 moveToRight 的值运行看一下效果:终于有效果了。所以实际是根据 moveToRight 的值改变导致传入 animateDpAsState 的 targetValue 参数的值发生改变,而动画执行的就是之前旧的值到当前设置最新值的动画效果。上面的 moveToRight 是 MutableState 类型, 内部的 value 是 Boolean 类型,那是不是只能是 Boolean 类型呢,当然不是,可以是任何类型,只要在传入 animateDpAsState 的参数值时根据这个类型的值进行自定义条件判断传入不同的数据即可,比如定义一个枚举类型,根据不同类型传入不同的参数,如下:甚至你可以直接创建一个跟动画值相同的数据类型,比如这里可以直接创建一个 Dp 类型的状态变量,然后在点击时直接改变其值来驱动动画执行,如下:上面代码同样能实现跟之前一样的效果。使用还是相当灵活的,开发中可以根据实际的需求定义不同的状态来完成我们想要的动画效果。animateXx免费云主机域名xAsState提供了动画完成时的监听finishedListener,可以通过监听动画完成进行自定义的业务处理,比如修改界面的显示状态或者开启下一个动画等。比如animateDpAsStatefinishedListener定义如下:有一个 Dp 类型的参数,即动画完成时的目标值,使用如下:比如我们想在上面的动画结束时再让方块移动回去,那我们可以这么写:效果如下:或者我们想让这个方块往返重复执行,可以这么写:效果如下:通过对animateXxxAsState动画的监听我们可以实现界面状态的刷新或进行动画的组合等自定义操作。前面讲了animateDpAsState动画的使用,其他animateXxxAsStateapi 的使用基本一样,只是动画作用的数据类型不一样,下面将通过一个个简单示例来看看其他几个 api 的使用。animateFloatAsState作用于 Float 类型数据的动画,比如 alpha 值,通过改变控件的 alpha 值可实现元素的显示与隐藏,使用示例如下:动画效果:animateIntAsState作用于 Int 数据类型,上面的animateDpAsState实现的动画也可以使用animateIntAsState实现,如下:效果跟使用animateDpAsState实现的一样:animateColorAsState是作用于 Color 上,可实现颜色的过渡动画,比如将上面的方块颜色从蓝色变为红色,代码如下:效果如下:animateSizeAsState作用于 Size 上,看到这个我们一下就想到了用于控件的 size 上,比如上面的Modifier.size()上,但实际上Modifier.size()的参数并不是 Size 类型,而是 Dp 类型或者DpSize,而 DpSize 并不是 Size 的子类,所以不能直接将 Size 类型的数据直接传入Modifier.size()中,而是需要转换一下:效果如下:animateIntSizeAsStateanimateSizeAsState几乎一样,只是它作用于IntSize,跟 Size 的唯一区别就是参数是 Int 类型而不是 Float 类型,如下:animateOffsetAsState作用于 Offset 类型数据,用于控制偏移量,同样的它不能直接用于Modifier.offset()上,因为Modifier.offset()接收的也是 Dp 类型参数,所以也需要进行转换,如下:效果如下:animateIntOffsetAsState则作用于IntOffset类型数据,使用方法与上面一致,只是将 Float 类型换成 Int 类型:Modifier.offset()提供了一个返回 IntOffset 的函数参数,可以如下使用:animateRectAsState作用于Rect数据,即可以同时控制位置和大小,通过animateRectAsState可实现上面方块的位置和大小变化的动画,使用如下:效果如下:上面讲了animateXxxAsState动画 api 的基本使用,下面就用这些 api 来完成一个实战效果,还是上一篇《Compose 中属性动画的使用》的效果:前面说了animateXxxAsState是依赖于状态的动画,分析上面的动画一共存在 4 个状态:默认状态:显示蓝色矩形按钮,文字为 Upload开始上传状态:按钮变为圆形且中间为白色,边框为灰色,文字消失上传中状态:边框根据进度变为蓝色上传完成状态:按钮从圆形回到圆角矩形,且颜色变为红色,文字变为 Success实现原理如下:首先通过一个枚举定义上述四种状态:然后实现默认状态的界面展示:然后根据上传按钮的状态定义不同状态时的数据值:此时运行后点击按钮效果如下:点击后只有开始上传的动画,没有后续的动画效果,这是因为我们在点击的时候只是将状态变为了 UploadState.Start 而没有进行后续状态的改变,所以需要监听动画完成然后继续改变按钮的状态来实现完整的动画效果,代码修改如下:分别给按钮宽度变化动画和进度动画进行监听并修改其状态,这样就将整个动画串联起来了,最终效果如下:以上就是“AndroidCompose状态改变动画animateXxxAsState怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注百云主机行业资讯频道。

相关推荐: 如何使用Springboot接收前端Ajax发送的json

本文小编为大家详细介绍“如何使用Springboot接收前端Ajax发送的json”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何使用Springboot接收前端Ajax发送的json”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 02/24 14:40
下一篇 02/24 14:40

相关推荐