Android recyclerview的项目动画

时间:2018-07-05 05:08:44

标签: android

我有一个水平的回收站视图,我将为屏幕上可见且集中的项目设置动画。

  public MyViewholder(final View item) {
        super(itemView);
   //...
   item.setOnFocusChangeListener(new View.OnFocusChangeListener() {
            @Override
            public void onFocusChange(View v, boolean hasFocus) {
                if (hasFocus) {
                    Animation anim = AnimationUtils.loadAnimation(context, R.anim.scale_in);
                    card.startAnimation(anim);
                    anim.setFillAfter(true);
                } else {
                    Animation anim = AnimationUtils.loadAnimation(context, R.anim.scale);
                    card.startAnimation(anim);
                    anim.setFillAfter(true);
                }
            }
            });
}

问题是recyclerview的第一项只有动画,而其他项没有变化。

<android.support.v7.widget.CardView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginEnd="16dp"
    android:layout_marginStart="16dp"
    android:background="@null"
    android:elevation="8dp"
    app:cardCornerRadius="8dp"
    android:focusable="true"
    android:focusableInTouchMode="true"
    app:cardUseCompatPadding="true"
    android:id="@+id/card">

 ...

</android.support.v7.widget.CardView>

1 个答案:

答案 0 :(得分:-1)

尝试一下

  public MyViewholder(final View itemView) {
  super(itemView);
  itemView.setOnFocusChangeListener(new View.OnFocusChangeListener() {
        @Override
        public void onFocusChange(View v, boolean hasFocus) {
            if (hasFocus) {
                Animation anim = AnimationUtils.loadAnimation(context, R.anim.scale_in);
                itemView.startAnimation(anim);
                anim.setFillAfter(true);
            } else {
                Animation anim = AnimationUtils.loadAnimation(context, R.anim.scale);
                itemView.startAnimation(anim);
                anim.setFillAfter(true);
            }
        }
        });
  }