Dan*_*ñez 9 icons animation android floating-action-button
我试图找到关于如何创建FAB(设计支持库)的图标动画的文档,在搜索了一段时间后我找不到任何关于它的信息,Android开发人员中的AnimationDrawable引用对FAB不起作用即使该类是ImageView的子级.
但设法得到一个工作正常的解决方法.
Dan*_*ñez 14
我使用的技术类似于DrawableAnimation文档中公开的技术,并使用Property Animation API文档.
首先,我使用ValueAnimator类,以及一个int数组,其中包含您将在动画中使用的drawable的id.
final int[] ids = {R.drawable.main_button_1,R.drawable.main_button_2,R.drawable.main_button_3,R.drawable.main_button_4,R.drawable.main_button_5,R.drawable.main_button_6, R.drawable.main_button_7};
fab = (FloatingActionButton) findViewById(R.id.yourFabID);
valueAnimator = ValueAnimator.ofInt(0, ids.length - 1).setDuration(yourAnimationTime);
valueAnimator.setInterpolator( new LinearInterpolator() /*your TimeInterpolator*/ );
Run Code Online (Sandbox Code Playgroud)
然后设置一个AnimationUpdateListener,并使用方法FloatinActionButton.setImageDrawable(Drawable yourDrawable)定义图标行为的更改.
然而,ValueAnimator默认更新每个可用的帧(取决于硬件中的负载),但是如果已经绘制了图标,我们不需要重绘图标,这就是我使用变量"i"的原因; 因此,一旦图标被下一个图标替换,代码就会等到下一个图标被绘制的时候.(时间取决于您定义的插补器)
valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
int i = -1;
@Override
public void onAnimationUpdate(ValueAnimator animation) {
int animatedValue = (int) animation.getAnimatedValue();
if(i!=animatedValue) {
fab.setImageDrawable(getResources().getDrawable(ids[animatedValue]));
i = animatedValue;
}
}
});
Run Code Online (Sandbox Code Playgroud)
当您使用该方法向后播放动画时,它也很有用 ValueAnimator.reverse();
我知道这不是一个专业的解决方案,但它是我唯一能够在所有支持PropertyAnimation的API上工作的解决方案.如果您知道更好的解决方案,请在此处发布,如果不是,我希望这篇文章有用
| 归档时间: |
|
| 查看次数: |
7110 次 |
| 最近记录: |