public class DebugExampleFour extends Activity {
private int numButtons = 1;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.debug_example_four);
final ViewGroup frame = (ViewGroup) findViewById(R.id.frame_container);
LayoutTransition transitioner = new LayoutTransition();
Animator appearingAnimation = ObjectAnimator.ofFloat(null,"translationX",600,0);
appearingAnimation.setDuration(45);
appearingAnimation.setStartDelay(0);
appearingAnimation.setInterpolator(new DecelerateInterpolator());
appearingAnimation.addListener(new AnimatorListenerAdapter() {
public void onAnimationEnd(Animator anim) {
View view = (View) ((ObjectAnimator) anim).getTarget();
view.setTranslationX(0f);
}
});
transitioner.setAnimator(LayoutTransition.APPEARING,appearingAnimation);
Animator dummyAnimation = ObjectAnimator.ofInt(0,1);
dummyAnimation.setDuration(1);
dummyAnimation.setStartDelay(0);
transitioner.setAnimator(LayoutTransition.CHANGE_APPEARING,dummyAnimation);
transitioner.setAnimator(LayoutTransition.CHANGE_DISAPPEARING,dummyAnimation);
transitioner.setAnimator(LayoutTransition.DISAPPEARING,dummyAnimation);
frame.setLayoutTransition(transitioner);
Button addButton = (Button) findViewById(R.id.addNewButton);
addButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
Button newButton = new Button(DebugExampleFour.this);
newButton.setText("Click To Remove " + (numButtons++));
newButton.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
frame.removeView(v);
}
});
frame.addView(newButton,new LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT));
}
});
}
}
这里是与该示例一起的布局文件:
<?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:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="Add Button"
android:id="@+id/addNewButton" />
<LinearLayout android:orientation="vertical"
android:layout_width="match_parent" android:layout_height="match_parent"
android:id="@+id/frame_container" android:animateLayoutChanges="true" />
</LinearLayout>
如何在APPEARING动画之前消除延迟?
解决方法
这样做的原因是,LayoutTransition通常将是在容器中的对象上运行的一系列动画.所以,例如,如果你想要一个对象在容器中“出现”,那么转换将首先使其他对象动画化,然后将新对象动画化到位.想象一下,将一个项目添加到一组对象的中间(如在ApiDemos应用程序中看到的那样);它首先使空间,然后淡化对象.
在上述原始代码的情况下,您希望显示的动画立即运行,因此您应该将APPEARING的转换startDelay设置为0(与上面的答案一样).
以另一种方式,默认情况下,DISAPPEARING动画没有startDelay,但是CHANGE_DISAPPEARING动画的startDelay等于DISAPPEARING动画的持续时间,假设您首先要删除项,然后将容器中的其他项目动画化为新地方
由于这些假设并不一定适用于每种情况,因此LayoutTransition上有duration / startDelay属性以根据您在特定情况下的需要来控制行为.
还要注意,如果您不想运行其中一个动画类型,则应将该动画设置为null(请参阅LayoutTransition.setAnimator(int,Animator)的文档).将其设置为dummyAnimator将不会产生相同的效果.一方面,即使为这些动画提供自定义动画效果,LayoutTransition上的默认持续时间/ startDelay值仍然适用.
还有其他一些要注意的事情:底层的时机机制(对于Android,也是大多数其他我曾经使用的平台)的时间安排机制将会有一些最低的分辨率.所以你设置一个持续时间’1′,这可能不会导致该动画以1ms结束.相反,它将运行一帧,然后运行在下一帧(通常是一个运行良好的应用程序中的设备的刷新率,如果系统没有陷入僵局),它将看到动画应该结束.

