android动画效果大全
转载请注明出处:https://blog.****.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.****.net/u011038298/article/details/84637788
动画效果图: