简单的任务:按下按钮,它将x值缩放到0,当动画完成时,在第二个视图上启动另一个动画,该视图将x从0缩放到1。1秒后应该播放反向动画,仅此而已。运行下面的代码我得到了动画第一部分的无限动画循环。
使用了nineoldandroids库,但我不认为这与本地动画框架有什么不同,至少在果冻豆设备上是这样。
public class MainActivity extends Activity
{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final View mybutton = findViewById(R.id.mybutton);
final View myprogress = findViewById(R.id.myprogress);
mybutton.setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
animate(mybutton).scaleX(0).setListener(new AnimatorListenerAdapter()
{
@Override
public void onAnimationEnd(Animator animation)
{
mybutton.setVisibility(View.INVISIBLE);
myprogress.setVisibility(View.VISIBLE);
ViewHelper.setScaleX(myprogress, 0f);
animate(myprogress).scaleX(1).setListener(new AnimatorListenerAdapter()
{
@SuppressWarnings("ConstantConditions")
@Override
public void onAnimationEnd(Animator animation)
{
mybutton.getHandler().postDelayed(new Runnable()
{
@Override
public void run()
{
animate(myprogress).scaleX(0).setListener(new AnimatorListenerAdapter()
{
@Override
public void onAnimationEnd(Animator animation)
{
myprogress.setVisibility(View.INVISIBLE);
mybutton.setVisibility(View.VISIBLE);
ViewHelper.setScaleX(mybutton, 0);
animate(mybutton).scaleX(1);
}
});
}
}, 1000);
}
});
}
});
}
});
}
}
布局简单:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
>
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/mycontainer">
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="string text"
android:id="@+id/mybutton"
/>
<ProgressBar
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignLeft="@id/mybutton"
android:layout_alignTop="@id/mybutton"
android:layout_alignRight="@id/mybutton"
android:layout_alignBottom="@id/mybutton"
android:visibility="invisible"
android:id="@+id/myprogress"
/>
</RelativeLayout>
</RelativeLayout>
我错在哪里了?
最佳答案
疯狂!
经调查发现其来源:
调用animate()方法时,它将创建viewPropertyImator并将其保存到地图中。
当您尝试使用animate()再次设置此视图的动画时,它将从映射中获取已创建的viewPropertyImator,并在设置新动画参数之前立即调用animationStart(),并且由于animationListener是在第一个动画上设置的,因此它被触发!并启动了第一个动画(第二部分)。这是创建无限循环。
若要停止此操作,必须在第二次尝试设置视图动画时清除旧侦听器,因此
animate(mybutton).setListener(null).scaleX(1);
停止无限循环。
文档应该警告它,当然!