布局变更动画
最后更新于:2022-04-01 01:39:46
> 编写:[XizhiXu](https://github.com/XizhiXu) - 原文:[http://developer.android.com/training/animation/layout.html](http://developer.android.com/training/animation/layout.html)
布局动画是一种预加载动画,系统在你每次改变的布局配置时运行它。你需要做的仅是在布局文件里设置属性告诉Android系统为你这些布局的变更应用动画。系统动画时为你默认执行的。
> **小贴士:** 如果你想补充自定义布局动画,创建 [LayoutTransition](http://developer.android.com/reference/android/animation/LayoutTransition.html) 对象和然后用 [ setLayoutTransition() ](http://developer.android.com/reference/android/view/ViewGroup.html#setLayoutTransition(android.animation.LayoutTransition)) 方法把它加到布局中。
下面是在一个list中添加一项的默认布局动画:
如果你想跳过看整个例子,[下载](http://developer.android.com/shareables/training/Animations.zip) App 样例然后运行布局渐变的例子。查看下列文件中的代码实现:
1. src/LayoutChangesActivity.java
1. layout/activity_layout_changes.xml
1. menu/activity_layout_changes.xml
### 创建布局
在你[activity](# "An activity represents a single screen with a user interface.")的XML布局文件中,为你想开启动画的布局设置 `android:animateLayoutChanges` 属性为真。例如:
~~~
<LinearLayout android:id="@+id/container"
android:animateLayoutChanges="true"
...
/>
~~~
### 从布局中添加,更新或删除项目
现在,你需要做的就是添加,删除或更新布局里的项目,然后这些项目就会自动显示动画啦:
~~~
private ViewGroup mContainerView;
...
private void addItem() {
View newView;
...
mContainerView.addView(newView, 0);
}
~~~