关于ViewGroup中添加子View的统一入场/出场动画
layoutAnimation:布局动画
api1中就有的方法,所以添加的动画时Animation。该属性只对创建ViewGroup时,对其子View有动画。已经创建过了该ViewGroup的话,再向其添加子View不会有动画。
什么时候是创建的时候:在onCreat方法中(不清楚具体时间点),在代码中生成的Viewgroup。
- onCreat创建加载布局时:
<?xml version="1.0" encoding="utf-8"?>
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_interpolator"
android:fromDegrees="0"
android:toDegrees="270"
android:pivotX="50%"
android:pivotY="50%"
android:duration="1000"
android:repeatMode = "reverse"
android:repeatCount = "3"
android:fillAfter = "true"
>
</rotate>
// layoutAnimation标签
<?xml version="1.0" encoding="utf-8"?>
<layoutAnimation
xmlns:android="http://schemas.android.com/apk/res/android"
android:delay="1"
android:animationOrder="normal"
android:animation="@anim/rotate_anim">
</layoutAnimation>
//定义在LinearLayout上,在该界面生成时,Button显示动画。但是,后面在LinearLayout中添加Button时,不再有动画。
<LinearLayout
android:id="@+id/ll_tips_target_animation"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layoutAnimation="@anim/layout_animation"
android:tag="在xml中设置的layoutAnimation"
android:orientation="vertical">
<Button
style="@style/base_button"
android:text="ViewGroup初始化时,子View有动画"/>
</LinearLayout>
- 代码中动态设置layoutAnimation,添加View
//代码生成ViewGroup
LinearLayout linear = new LinearLayout(this);
Animation animation = AnimationUtils.loadAnimation(this, R.anim.rotate_anim);
LayoutAnimationController controller = new LayoutAnimationController(animation);
controller.setDelay(1);
//动画模式,正常/倒叙/随机
controller.setOrder(LayoutAnimationController.ORDER_NORMAL);
//设置layoutAnimation
linear.setLayoutAnimation(controller);
linear.setLayoutAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
Log.e(TAG, "onAnimationStart: start" );
}
@Override
public void onAnimationEnd(Animation animation) {
Log.e(TAG, "onAnimationEnd: end" );
}
@Override
public void onAnimationRepeat(Animation animation) {
Log.e(TAG, "onAnimationRepeat: repeat" );
}
});
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT);
linear.setLayoutParams(params);
//给该ViewGroup添加子View,子View会有动画。
addVeiw(linear,null);
//创建的新ViewGroup添加,显示出来
llTargetAnim.addView(linear, 0);
- 使用场景:
该属性只有ViewGroup创建的时候才能有效果,所以不适合动态添加子View的操作显示动画。一般做界面显示的时候的入场动画,比如打开一个界面,多个固定不变的item有动画的显示出来。(进入设置界面,信息展示界面)。
android:animateLayoutChanges属性:
Api11后,添加/移除子View时所带的默认动画,在Xml中设置。不能自定义动画,只能使用默认的。所以,使用范围较小。
<LinearLayout
android:animateLayoutChanges="true"
/>
image
LayoutTransition 布局容器动画
animateLayoutChanges只能使用默认动画,LayoutTransition可以自定义动画,并且也不用非得创建ViewGroup时才能显示动画,后面添加子View也能显示。
LayoutTransition layoutTransition = new LayoutTransition();
//添加的View显示动画
ObjectAnimator animatorAdd = ObjectAnimator.ofFloat(null,"ScaleX",1.0f,1.5f,1.0f);
animatorAdd.setDuration(1000);
layoutTransition.setAnimator(LayoutTransition.APPEARING, animatorAdd);
//添加View时,已经有的View显示的动画。但是demo没有显示该动画。
PropertyValuesHolder valuesHolder = PropertyValuesHolder.ofFloat("rotation",0f,22f,0f);
ValueAnimator animatorOld = ObjectAnimator.ofPropertyValuesHolder(llTargetAnim, valuesHolder);
animatorOld.setDuration(2000);
layoutTransition.setAnimator(LayoutTransition.CHANGE_APPEARING, animatorOld);
layoutTransition.addTransitionListener(new LayoutTransition.TransitionListener() {
@Override
public void startTransition(LayoutTransition transition, ViewGroup container, View view, int transitionType) {
Log.e(TAG, "startTransition: start" );
}
@Override
public void endTransition(LayoutTransition transition, ViewGroup container, View view, int transitionType) {
Log.e(TAG, "endTransition: end" );
}
});
llTargetAnim.setLayoutTransition(layoutTransition);
addVeiw(llTargetAnim,"添加的View动画和已有View的动画");
LayoutTransition有很多坑,属性值第一和最后一个什么时候必须一样,什么时候必须用PropertyValuesHolder封装属性...不研究了,麻蛋就这样.