属性动画ValueAnimtor和ObjectAnimtor

<ImageView
    android:id="@+id/img"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@drawable/a"/>

<Button
    android:id="@+id/btn"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/img"
    android:layout_alignParentStart="true"
    android:text="ValueAnimtor开始动画" />

<Button
    android:id="@+id/btn1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_below="@+id/btn"
    android:layout_alignParentStart="true"
    android:text="ObjectAnimtor开始动画" />
public class MainActivity extends AppCompatActivity {

    private ImageView img;
    private Button btn;
    private Button btn1;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        img = findViewById(R.id.img);
        btn = findViewById(R.id.btn);
        btn1 = findViewById(R.id.btn1);

        //ObjectAnimtor
        btn1.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                //平移
                ObjectAnimator transition=ObjectAnimator.ofFloat(img,"TranslationX",0,100,200);
                //旋转
                ObjectAnimator rotate=ObjectAnimator.ofFloat(img,"Rotation",0,360);
                //透明度
                ObjectAnimator alpha=ObjectAnimator.ofFloat(img,"Alpha",0,100);
                //缩放
                ObjectAnimator scaleX=ObjectAnimator.ofFloat(img,"ScaleX",0,1);
                AnimatorSet animatorSet=new AnimatorSet();
                //执行顺序
                animatorSet.play(transition).with(rotate).with(scaleX).before(alpha);
                animatorSet.setDuration(5000);
                animatorSet.start();
            }
        });

        //ValueAnimtor
        btn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                ValueAnimator valueAnimator=ValueAnimator.ofInt(0,1000);
                valueAnimator.setDuration(6000);
                valueAnimator.setStartDelay(5000);
               valueAnimator.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
                   @Override
                   public void onAnimationUpdate(ValueAnimator animation) {
                       int value = (int) animation.getAnimatedValue();
                       //重新给他赋值
                       img.getLayoutParams().width=value;
                       //刷新视图
                       img.requestLayout();
                   }
               });
               //开始动画
                valueAnimator.start();
            }
        });

    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值