自定义View——聚焦动画控件

我尽量不打错别字,用词准确,不造成阅读障碍。

这个自定义View是很简单的一个,效果是在拍摄图片时的对焦动画,在自定义SurfaceView中使用这个控件就好了。

效果如下:

在这里插入图片描述

代码:

public class FocusView extends View {
	private Paint mLinePaint;        //画笔
	private int mBorderWidth = 4;    //圆环的宽

	private AnimatorSet animSet;
	private ObjectAnimator fadeInOut;
	private boolean isFocusing = false;

	public FocusView(Context context) {
		super(context);
		init();
	}

	public FocusView(Context context, AttributeSet attrs) {
		super(context, attrs);
		init();
	}

	public FocusView(Context context, AttributeSet attrs, int defStyleAttr) {
		super(context, attrs, defStyleAttr);
		init();
	}

    //初始化
	private void init() {
		mLinePaint = new Paint();
		mLinePaint.setAntiAlias(true);
		mLinePaint.setStyle(Paint.Style.STROKE);
		mLinePaint.setColor(Color.parseColor("#45ffffff"));
		mLinePaint.setStrokeWidth(mBorderWidth);
		this.setAlpha(0f);  //初始化设置透明
	}

	private void setMainColor() {
		mLinePaint.setColor(getResources().getColor(R.color.colorPrimaryDark));
		postInvalidate();
	}

	private void reSet() {
		mLinePaint.setColor(Color.parseColor("#52ce90"));
		postInvalidate();
	}

	@Override
	protected void onDraw(Canvas canvas) {
        //其实就是画个圆
		canvas.drawCircle(getWidth() / 2, getHeight() / 2, getHeight() / 2 - mBorderWidth / 2, mLinePaint);
	}

    //开始动画,这个方法暴露给外界调用
	public void beginFocus() {
		isFocusing = true;
		if (animSet == null) {
            //设置X轴动画为1倍-->1.3倍-->1倍,也可以使用具体的缩放动画类
			ObjectAnimator scaleX = ObjectAnimator.ofFloat(this, "scaleX", 1f, 1.3f, 1f);
            //设置Y轴动画为1倍-->1.3倍-->1倍,也可以使用具体的缩放动画类
			ObjectAnimator scaleY = ObjectAnimator.ofFloat(this, "scaleY", 1f, 1.3f, 1f);
			animSet = new AnimatorSet();
			animSet.play(scaleX).with(scaleY);                  //设置X轴和Y轴同时执行
			animSet.setInterpolator(new LinearInterpolator());  //线性插值器,即匀速执行
			animSet.setDuration(1000);                          //施行时间1秒
			animSet.addListener(new Animator.AnimatorListener() {
				@Override
				public void onAnimationStart(Animator animation) {
					FocusView.this.setAlpha(1f);  //在动画开始时显示view
				}
				@Override
				public void onAnimationRepeat(Animator animation) {
				}
				@Override
				public void onAnimationEnd(Animator animation) {
					setMainColor();
					if(fadeInOut == null) {
                        //在动画结束后启用另一个动画,透明度变化
						fadeInOut = ObjectAnimator.ofFloat(FocusView.this, "alpha", 1f, 0f);
						fadeInOut.setDuration(500);
						fadeInOut.addListener(new Animator.AnimatorListener() {
							@Override
							public void onAnimationStart(Animator animation) {
							}
							@Override
							public void onAnimationEnd(Animator animation) {
								reSet();
								isFocusing = false;
							}
							@Override
							public void onAnimationCancel(Animator animation) {
							}
							@Override
							public void onAnimationRepeat(Animator animation) {
							}
						});
					}
					fadeInOut.start();
				}
				@Override
				public void onAnimationCancel(Animator animation) {
				}
			});
		} else {
			if(animSet.isRunning()) {
				animSet.cancel();
			}
			if(fadeInOut != null && fadeInOut.isRunning()) {
				fadeInOut.cancel();
			}
		}
		animSet.start();
	}

	public boolean isFocusing() {
		return isFocusing;
	}
}

大体上是这个思路,具体的圆环样式和动画实现方法可以根据具体的情况更改。

集合了一些简单自定义View的github地址:
https://github.com/longlong-2l/MySelfViewDemo
很简单,没有太多高深的用法,适合学习入门。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值