android动画效果大全

转载请注明出处:https://blog.csdn.net/u011038298/article/details/84837532

import android.animation.Animator;
import android.animation.AnimatorListenerAdapter;
import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.view.ViewAnimationUtils;
import android.widget.ImageView;

public class MainActivity extends AppCompatActivity {

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

        final CircleImageView circleImageView = findViewById(R.id.circle_image_view);
        circleImageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
        circleImageView.setImageResource(R.mipmap.background_image);

        circleImageView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                final int width = circleImageView.getMeasuredWidth();
                final int height = circleImageView.getMeasuredHeight();
                final float radius = (float) Math.sqrt(width * width + height * height);
                if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.LOLLIPOP) {
                    // 第一个参数是执行揭露动画的 View 视图
                    // 第二个参数是相对于视图 View 的坐标系,动画圆的中心的x坐标
                    // 第三个参数是相对于视图 View 的坐标系,动画圆的中心的y坐标
                    // 第四个参数是动画圆的起始半径,
                    // 第五个参数动画圆的结束半径。
                    Animator animator = ViewAnimationUtils.createCircularReveal(circleImageView, width / 2, height / 2, 0, radius);
                    animator.addListener(new AnimatorListenerAdapter() {
                        @Override
                        public void onAnimationEnd(Animator animation) {
                            // 动画结束
                        }
                    });
                    // 设置动画持续时间(单位:毫秒)
                    animator.setDuration(1000 * 2);
                    animator.start();
                }

            }
        });

    }

}

圆形控件:https://blog.csdn.net/u011038298/article/details/84637788

动画效果图:

 

猜你喜欢

转载自blog.csdn.net/u011038298/article/details/84837532