BRVAH动画解析

此篇文章引用代码为BRVAH的源码,源码地址https://github.com/CymChad/BaseRecyclerViewAdapterHelper

前言

BRVAH一共有七种动画体现,在此之前自己从不曾接触动画,总以为很难入门。须求各类精美的测算还有算法等,前几天硬着头皮看了看,发现入门仍然相比较容易的。至少这篇小说我能有限支撑你看懂。BRVAH的卡通片用法在此间就不详细表达了,官方已经有详实的诠释博客,有少数就是他的规律分析不是入门级别。

代码

从下边可以观察addAnimation(holder)拉长动画的章程,是在onViewAttachedToWindow那几个主意中调用的。这么些措施是在recyclerview的item展现在显示屏上时调用的。

 @Override
    public void onViewAttachedToWindow(K holder) {
        super.onViewAttachedToWindow(holder);
        int type = holder.getItemViewType();
        if (type == EMPTY_VIEW || type == HEADER_VIEW || type == FOOTER_VIEW || type == LOADING_VIEW) {
            setFullSpan(holder);
        } else {
            addAnimation(holder);
        }
    }

接下去看一下以此addAnimation艺术,先是判断是不是开启动画然后对动画实体类的getAnimators方法举行遍历,因为一个item可能有多少个卡通,比如横向拉伸动画和纵向拉伸动画。可以先实施横向拉伸在履行纵向拉伸。

 private void addAnimation(RecyclerView.ViewHolder holder) {
        if (mOpenAnimationEnable) {
            if (!mFirstOnlyEnable || holder.getLayoutPosition() > mLastPosition) {
                BaseAnimation animation = null;
                if (mCustomAnimation != null) {
                    animation = mCustomAnimation;
                } else {
                    animation = mSelectAnimation;
                }
                for (Animator anim : animation.getAnimators(holder.itemView)) {
                    startAnim(anim, holder.getLayoutPosition());
                }
                mLastPosition = holder.getLayoutPosition();
            }
        }
    }

切切实实来看getAnimators方法,由于三种动画不一致,所以animation的类中的动画方法也相差很大。那其间都用到了一个ObjectAnimator类,那个类是专程针对控件举办监听的,监听动画进度,在监听中对控件操作。
ofFloat()是改变透明度的措施
public static ObjectAnimator ofFloat(Object target, String
propertyName, float… values)

第三个参数用于指定这么些动画要操作的是哪个控件
其次个参数用于指定这么些动画要操作这一个控件的哪个属性
其七个参数是可变长参数,那个就跟 ValueAnimator
中的可变长参数的意思一样了,就是指这么些属性值是从哪变到哪。
明白了这几个上边的代码就简单了,只顾上边代码中的注释!!!

mFrom为自定义数值
//**AlphaInAnimation类**
/*alpha 渐变透明度动画效果,从0f到1f*/
     @Override
    public Animator[] getAnimators(View view) {//(改变透明度)
        return new Animator[]{ObjectAnimator.ofFloat(view, "alpha", mFrom, 1f)};
    }
//
//**ScaleInAnimation类**
/*scale 调节尺寸,1.0 代表自身无变化,0.5 代表起始时缩小一倍,2.0 代表放大一倍,这里从0.5到1*/
    @Override
    public Animator[] getAnimators(View view) {
        ObjectAnimator scaleX = ObjectAnimator.ofFloat(view, "scaleX", mFrom, 1f);
        ObjectAnimator scaleY = ObjectAnimator.ofFloat(view, "scaleY", mFrom, 1f);
        return new ObjectAnimator[]{scaleX, scaleY};
    }
//**SlideInBottomAnimation类**
/*translate 标签 —— 平移,这里是Y轴方向平移。起始的item都是上下都是紧凑的,这个动画就是在Y轴上从远处向最终位置平移一个单位,以item的高为标准作为一个单位*/
 @Override
    public Animator[] getAnimators(View view) {
        return new Animator[]{
                ObjectAnimator.ofFloat(view, "translationY", view.getMeasuredHeight(), 0)
        };
    }
/*这个跟上面区别不是很大,就是在X轴上平移一个单位*/
//**SlideInLeftAnimation类**
     @Override
    public Animator[] getAnimators(View view) {
        return new Animator[]{
                ObjectAnimator.ofFloat(view, "translationX", -view.getRootView().getWidth(), 0)
        };
    }
//**SlideInRightAnimation类**
    @Override
    public Animator[] getAnimators(View view) {
        return new Animator[]{
                ObjectAnimator.ofFloat(view, "translationX", view.getRootView().getWidth(), 0)
        };
    }

startAnim方法是举行动画的办法,首先设定执行的周期,然后设定动画变化的速率,速率有很多样本文接纳的是LinearInterpolator,以常量速率改变。

protected void startAnim(Animator anim, int index) {
        anim.setDuration(mDuration).start();
        anim.setInterpolator(mInterpolator);
    }

想要了然动画其余质量的可以看一下以此科目http://wiki.jikexueyuan.com/project/android-animation/2.html

感兴趣的同窗可以关心一下自家的微信公众号,或者微信搜索 开发
Android的小学生

image.png

发表评论

电子邮件地址不会被公开。 必填项已用*标注