使用LayoutTransition实现布局变化时的动画

2024-05-07 02:48

本文主要是介绍使用LayoutTransition实现布局变化时的动画,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

随时随地技术实战干货,获取项目源码、学习资料,请关注源代码社区公众号(ydmsq666)

在3.0及以后只需要在XML中设置animateLayoutChanges="true"或者在Java代码中添加一个LayoutTransition对象即可实现任何ViewGroup布局改变时的动画。

目前系统中支持以下5种状态变化,应用程序可以为下面任意一种状态设置自定义动画:

1、APPEARING:容器中出现一个视图。

2、DISAPPEARING:容器中消失一个视图。

3、CHANGING:布局改变导致某个视图随之改变,例如调整大小,但不包括添加或者移除视图。

4、CHANGE_APPEARING:其他视图的出现导致某个视图改变。

5、CHANGE_DISAPPEARING:其他视图的消失导致某个视图改变。

下面举个实例,动态的向容器中添加和移除组件来实现布局变化得动画效果,XML如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical" ><Button android:id="@+id/main_btn"android:layout_width="match_parent"android:layout_height="wrap_content"android:text="添加控件"/><LinearLayout android:layout_width="match_parent"android:layout_height="match_parent"android:animateLayoutChanges="true"android:id="@+id/main_container"android:orientation="vertical"/></LinearLayout>


注意在容器中设置了属性android:animateLayoutChanges="true",这个时候容器布局改变就已经有动画效果了,只不过是系统默认的,比如添加一个按钮会出现渐入动画,移除一个按钮会出现渐出动画,而周围的视图则会平滑地填充移除时的空隙。

但是如果我们想自定义这些效果怎么办呢?使用LayoutTransition。代码如下:

public class MainActivity extends Activity implements OnClickListener {private LinearLayout mContainer;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);mContainer = (LinearLayout) findViewById(R.id.main_container);LayoutTransition transition = new LayoutTransition();mContainer.setLayoutTransition(transition);findViewById(R.id.main_btn).setOnClickListener(this);//使用翻转进入的动画代替默认动画Animator appearAnim = ObjectAnimator.ofFloat(null, "rotationY", 90f, 0).setDuration(transition.getDuration(LayoutTransition.APPEARING));transition.setAnimator(LayoutTransition.APPEARING, appearAnim);//使用翻转消失的动画代替默认动画Animator disappearAnim = ObjectAnimator.ofFloat(null, "rotationX", 0,90f).setDuration(transition.getDuration(LayoutTransition.DISAPPEARING));transition.setAnimator(LayoutTransition.DISAPPEARING, disappearAnim);//使用滑动动画代替默认布局改变的动画//这个动画会让视图滑动进入并短暂地缩小一半,具有平滑和缩放的效果PropertyValuesHolder pvhSlide = PropertyValuesHolder.ofFloat("y", 0, 1);PropertyValuesHolder pvhScaleY = PropertyValuesHolder.ofFloat("scaleY",1f, 0.5f, 1f);PropertyValuesHolder pvhScaleX = PropertyValuesHolder.ofFloat("scaleX",1f, 0.5f, 1f);//这里将上面三个动画综合Animator changingDisappearAnim = ObjectAnimator.ofPropertyValuesHolder(this, pvhSlide, pvhScaleY, pvhScaleX);changingDisappearAnim.setDuration(transition.getDuration(LayoutTransition.CHANGE_DISAPPEARING));transition.setAnimator(LayoutTransition.CHANGE_DISAPPEARING,changingDisappearAnim);}@Overridepublic void onClick(View view) {Button btn = new Button(this);btn.setText("移除自己");btn.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {mContainer.removeView(v);}});mContainer.addView(btn, new LinearLayout.LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.WRAP_CONTENT));}

mContainer.setLayoutTransition(transition)为容器绑定一个LayoutTransition对象。接下来为transition设置了几种系统支持类型的布局改变时动画,动画时间都是取系统默认的时间,另外关于属性动画ObjectAnimator的使用,可以参照guolin大神的博客Android属性动画完全解析(上),初识属性动画的基本用法

最后一个过渡动画稍微有点复杂,需要创建一个动画,让周围的视图可以平滑地运动到新的位置上,滑动的同时会产生缩放效果。为了实现这个效果,需要通过PropertyValuesHolder实例创建一个ObjectAnimator来设置一些属性。动画的每个属性都是单独的PropertyValuesHolder,并且通过ofPropertyValuesHolder工厂方法添加到Animator对象中。最后这个过渡动画使移除的按钮下面的所有按钮向上滑动到刚刚空出的位置,同时稍微收缩一下。

这篇关于使用LayoutTransition实现布局变化时的动画的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/966113

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib