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结束.相反,它将运行一帧,然后运行在下一帧(通常是一个运行良好的应用程序中的设备的刷新率,如果系统没有陷入僵局),它将看到动画应该结束.