Android Compose Transition 动画

Transition 是一种动画效果,用于在组件的状态之间进行平滑的过渡。它可以帮助我们在状态变化时,以一种流畅的方式更新 UI。通过使用 Compose 的 Transition API,您可以在应用中创建各种各样的动画效果,从而增强用户体验并提高应用的吸引力。


在 Compose 中推荐使用 updateTransition 来创建 Transition 动画,因为可以进行预览。

用法:

@Preview(showBackground = true)
@Composable
fun MyScreen() {
    var isVisible by remember { mutableStateOf(true) }

    val transition = updateTransition(targetState = isVisible, label = "kang")
    val colorAnimate by transition.animateColor(transitionSpec = { tween(300) }, label = "colorAnimate") {
        if (it) Color(0xFF03A9F4) else Color(0xFFFFEB3B)
    }
    val dpAnimate by transition.animateDp(transitionSpec = { tween(300) }, label = "dpAnimate") {
        if (it) 0.dp else 25.dp
    }
    val sizeAnimate by transition.animateSize(transitionSpec = { tween(300) }, label = "sizeAnimate") {
        if (it) Size(150f, 60f) else Size(270f, 50f)
    }

    Column(
        modifier = Modifier
            .fillMaxWidth()
            .padding(16.dp),
        verticalArrangement = Arrangement.Center,
        horizontalAlignment = Alignment.CenterHorizontally
    ) {
        Box(
            modifier = Modifier
                .size(sizeAnimate.width.dp, sizeAnimate.height.dp)
                .background(colorAnimate, RoundedCornerShape(dpAnimate))
                .clickable(interactionSource = MutableInteractionSource(), indication = null) {
                    isVisible = !isVisible
                }
                .padding(15.dp),
            contentAlignment = Alignment.Center
        ) {
            Text(text = "Hello, wk灬丨!", color = Color.Gray)
        }
    }
}

代码直接贴上去之后点击 Split 就可以直接进行预览了:


在最新的 Android Studio 使用 updateTransition 可以进行 Compose 动画预览。点击:


之后出现的画面就是 compose 的动画预览页了,下面的进度条可以拖动进行动画预览


也可以展开动画预览它的曲线:

 虽然预览能够很清晰的看到具体的曲线和动画变换的过程,但是非常可以不能编辑,若能在如此详细的预览页能够编辑,那每一位开发制作动画都非常方便了(甚至有点视频剪辑的感觉)

相关推荐

  1. android ——动画

    2023-12-15 09:20:04       39 阅读
  2. WPF —— 动画

    2023-12-15 09:20:04       10 阅读
  3. Android UI:动画:视图动画

    2023-12-15 09:20:04       11 阅读
  4. Android UI:动画:帧动画

    2023-12-15 09:20:04       9 阅读
  5. css连续动画动画组)

    2023-12-15 09:20:04       5 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-15 09:20:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-15 09:20:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-15 09:20:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-15 09:20:04       18 阅读

热门阅读

  1. html2canvas库——前端实现基于DOM的截图

    2023-12-15 09:20:04       42 阅读
  2. xml.dom --- 文档对象模型 API

    2023-12-15 09:20:04       31 阅读
  3. OpenShift与Rancher

    2023-12-15 09:20:04       28 阅读
  4. HTML中RGB颜色表示法和RGBA颜色表示法

    2023-12-15 09:20:04       37 阅读
  5. 【Oracle】常用数据库sql记录

    2023-12-15 09:20:04       27 阅读
  6. 200. 岛屿数量

    2023-12-15 09:20:04       32 阅读
  7. 【C++】简化for-range的算法函数

    2023-12-15 09:20:04       39 阅读
  8. MPI和C++/Qt混用的收发消息的例子(主从模式)

    2023-12-15 09:20:04       30 阅读
  9. redis集群模糊获取缓存redisKey

    2023-12-15 09:20:04       40 阅读
  10. ES6简化对象

    2023-12-15 09:20:04       33 阅读
  11. zookeeper集群安装

    2023-12-15 09:20:04       33 阅读