BPRADOVAH动画解析

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

前言

B奥迪Q5VAH一共有多样动画浮现,之前本身从没有接触动画,总以为很难入门。须要种种精制的估摸还有算法等,明日硬着头皮看了看,发现入门如故比较简单的。至少那篇作品小编能保证你看懂。B凯雷德VAH的动画片用法在那里就不详细表达了,官方已经有详实的分解博客,有好几就是她的规律分析不是入门级别。

代码

从下面可以看看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

相关文章