仿快递柜开门动画

仿快递柜开门动画

实现效果
在这里插入图片描述
原理:
通过错切和宽度动画实现开关门效果

实现代码:
ButtonWrapper,实现按钮宽度动画

public class ButtonWrapper {
    private Button button;

    public ButtonWrapper(Button button) {
        this.button = button;
    }

    public int getWidth() {
        return button.getLayoutParams().width;
    }

    public void setWidth(int width) {
        button.getLayoutParams().width = width;
        button.requestLayout();
    }

    public int getHeight() {
        return button.getLayoutParams().height;
    }

    public void setHeight(int height) {
        button.getLayoutParams().height = height;
        button.requestLayout();
    }
}

SkewAnimation,实现错切效果

public class SkewAnimation extends Animation {

    private long duration;
    private boolean fillAfter;
    private boolean open;

    public Rotate3dAnimation(long duration, boolean fillAfter) {
        this.duration = duration;
        this.fillAfter = fillAfter;
    }

    public void setOpen(boolean open) {
        this.open = open;
    }

    @Override
    public void initialize(int width, int height, int parentWidth, int parentHeight) {
        super.initialize(width, height, parentWidth, parentHeight);
        setDuration(duration);
        setFillAfter(fillAfter);
    }

    @Override
    protected void applyTransformation(float interpolatedTime, Transformation t) {
        final Matrix matrix = t.getMatrix();
        matrix.reset();
        if (open) {
            matrix.setSkew(0, 0.2f * interpolatedTime);
        } else {
            matrix.setSkew(0, 0.2f * (1f - interpolatedTime));
        }
    }
}

代码使用

    public void openDoor(View view) {
        Rotate3dAnimation rotation = new Rotate3dAnimation(500, true);
        rotation.setOpen(true);
        button.startAnimation(rotation);
        ButtonWrapper wrapper = new ButtonWrapper(button);
        addViewSkewAnim = ObjectAnimator.ofInt(wrapper, "width", 143, 60);
        addViewSkewAnim.setDuration(500);
        addViewSkewAnim.start();

    }

    public void closeDoor(View view) {
        Rotate3dAnimation rotation = new Rotate3dAnimation(500, true);
        rotation.setOpen(false);
        button.startAnimation(rotation);
        ButtonWrapper wrapper = new ButtonWrapper(button);
        addViewSkewRevertAnim = ObjectAnimator.ofInt(wrapper, "width", 60, 143);
        addViewSkewRevertAnim.setDuration(500);
        addViewSkewRevertAnim.start();
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值