Android自定义XY(对角线)动画

  1. 继承Animation类
  2. 覆写applyTransformation(),initialize()

public class ERTXYAnimation extends Animation {
   /**  控件 */
    private View mView = null;
    /** 控件fromX */
    private int mFormX = 0;
    /** 控件fromY */
    private int mFormY = 0;
    /** 控件toX */
    private int mToX = 0;
    /** 控件toY */
    private int mToY = 0;

    public ERTXYAnimation(View view, float fromX, float fromY, float toX,
            float toY) {
        this.mView = view;
        this.mFormX = (int) fromX;
        this.mToX = (int) toX;
        this.mFormY = (int) fromY;
        this.mToY = (int) toY;
    }
    //在绘制动画的过程中会反复的调用applyTransformation 函数,每次调用参数interpolatedTime值都会变化,该参数从0渐变为1,当该参数为1时表明动画结束。通过参数Transformation 来获取变换的矩阵(matrix),通过改变矩阵就可以实现各种复杂的效果。
    @Override
    protected void applyTransformation(float interpolatedTime, Transformation t) {
        int x = (int) (mFormX + ((mToX - mFormX) * interpolatedTime));
        int y = (int) (mFormY + ((mToY - mFormY) * interpolatedTime));
        ViewGroup.LayoutParams l = mView.getLayoutParams();
        if (l instanceof AbsoluteLayout.LayoutParams) {
            AbsoluteLayout.LayoutParams al = (AbsoluteLayout.LayoutParams) l;
            al.x = x;
            al.y = y;
            mView.setLayoutParams(al);
            mView.invalidate();//直接调用invalidate()方法,请求重新draw(),但只会绘制调用者本身。
        } else {
            Utils.printLog("ERTXYAnimation", "Not AbsoluteLayout!  This Class can not handle it!!");
            return;
        }

    }

    //这是一个回调函数告诉Animation目标View的大小参数,在这里可以初始化一些相关的参数,例如设置动画持续时间、设置Interpolator、设置动画的参考点等。
    @Override
    public void initialize(int width, int height, int parentWidth,
            int parentHeight) {
        super.initialize(width, height, parentWidth, parentHeight);
    }

}

Android中的补间动画分为下面几种:
(1)AlphaAnimation :透明度改变的动画。
(2)ScaleAnimation:大小缩放的动画。
(3)TranslateAnimation:位移变化的动画。
(4)RotateAnimation:旋转动画。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值