view同时更新backgroundcolor和corner

因为corner在view里不是一个属性,不像iOS那样可以直接修改,所以需要适当的修改一笑已经有的实现。
Step 1

// 自定义属性,表示背景中的corner
public void setRadius(int radius) {
    this.radius = radius;
}

@Override
public void setBackgroundColor(int color) {
//        super.setBackgroundColor(color);
    //整个核心是这里
    GradientDrawable drawable = new GradientDrawable();
    drawable.setColor(color);
    drawable.setCornerRadius(radius);
    drawable.setShape(GradientDrawable.RECTANGLE);
    drawable.setStroke(2, Color.BLACK);
    setBackground(drawable);
}

Step 2

// 背景色设置动画
ObjectAnimator bg = ObjectAnimator.ofArgb(bgView, "BackgroundColor", 0xffff00ff, 0xffffff00, 0xffff00ff);
bg.setDuration(3000);
bg.setEvaluator(new ArgbEvaluator());
// 自定义view半径动画
ObjectAnimator radius = ObjectAnimator.ofInt(bgView, "radius", 100, 10);
radius.setDuration(8000);
// 动画集合
AnimatorSet set = new AnimatorSet();
set.playTogether(radius, bg);
set.setDuration(5000);
set.start();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值