目前,我正在尝试像RecyclerView
behaivior一样实现Google Inbox,我对电子邮件打开动画很好奇。
我的问题是:如何做到这一点?我的意思是,他们使用了哪种方法?他们是否使用ItemAnimator.dispatchChangeStarting()
并改变了它的高度来填充父母?还是别的什么?如果他们这样做了,他们如何通过拉动手势将其关闭,而底层RecyclerView
元素则略微可见。
谁能帮我指向一些库或代码片段/示例?
目前,我正在尝试像RecyclerView
behaivior一样实现Google Inbox,我对电子邮件打开动画很好奇。
我的问题是:如何做到这一点?我的意思是,他们使用了哪种方法?他们是否使用ItemAnimator.dispatchChangeStarting()
并改变了它的高度来填充父母?还是别的什么?如果他们这样做了,他们如何通过拉动手势将其关闭,而底层RecyclerView
元素则略微可见。
谁能帮我指向一些库或代码片段/示例?
你的意思是:recyclerview 作为一个加载项目,或者一旦一个项目并按下加载下一个屏幕。
我留下了一个例子,说明我如何在 recyclerview 中对物品进行收费,并给出一个动画
public class CreateAnimationView {
private static int contador;
Integer colorFrom = R.color.myAccentColor;
Integer colorTo = Color.RED;
public static AnimatorSet createAnimation(View view) {
ObjectAnimator fadeOut = ObjectAnimator.ofFloat(view, "alpha",
0f);
fadeOut.setDuration(300);
ObjectAnimator mover = ObjectAnimator.ofFloat(view,
"translationX", -500f, 0f);
mover.setDuration(400);
ObjectAnimator fadeIn = ObjectAnimator.ofFloat(view, "alpha",
0f, 1f);
fadeIn.setDuration(300);
AnimatorSet animatorSet = new AnimatorSet();
animatorSet.play(mover);
animatorSet.start();
return animatorSet;
}
... more animations methods.
}
在您的 RecyclerViewAdapter 中:
@Override
public void onBindViewHolder(ViewHolder viewHolder, int position) {
GruposCardView gruposCardView = gruposCardViews.get(position);
CreateAnimationView.createAnimationRandom(viewHolder.cardView);
...}
如果不在 recyclerview 中,您可以传递一个布局并使用此动画或从中创建一个。
public static AnimatorSet createAnimationCollapseXY(View view) {
ObjectAnimator scaleXOut = ObjectAnimator.ofFloat(view, "scaleX", 1f, 0f).setDuration(400);
ObjectAnimator scaleXIn = ObjectAnimator.ofFloat(view, "scaleX", 0f, 1f).setDuration(300);
ObjectAnimator scaleYOut = ObjectAnimator.ofFloat(view, "scaleY", 1f, 0f).setDuration(400);
ObjectAnimator scaleYIn = ObjectAnimator.ofFloat(view, "scaleY", 0f, 1f).setDuration(300);
ObjectAnimator rotateClockWise = ObjectAnimator.ofFloat(view, "rotation", 0f, 360f).setDuration(400);
ObjectAnimator rotateCounterClockWise = ObjectAnimator.ofFloat(view, "rotation", 0f, -360f).setDuration(400);
AnimatorSet animatorSet = new AnimatorSet();
animatorSet.playTogether(scaleXIn, scaleYIn);
//animatorSet.setStartDelay(1200);
animatorSet.start();
return animatorSet;
}