leen_wei 2019-04-18 15:52 采纳率: 100%
浏览 468
已采纳

自定义view使用动画的问题

最近在学习自定义view相关的东西,想实现一个画圆的动画,但是始终没有效果,代码如下:

public class AnimatorView extends View {
    private static final String TAG = "AnimatorView";

    private Paint mPaint;
    private RectF mArcRectF;
    private ObjectAnimator mProgressAnim;

    private int mProgress = 0;

    public AnimatorView(Context context) {
        this(context, null);
    }

    public AnimatorView(Context context, AttributeSet attrs) {
        this(context, attrs, 0);
    }

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

    private void init() {
        if(mPaint == null)
            mPaint = new Paint();
        setLayerType(View.LAYER_TYPE_SOFTWARE, null);
        mPaint.setAntiAlias(true);
        mPaint.setStyle(Paint.Style.STROKE);
        mPaint.setColor(Color.RED);
        mPaint.setStrokeWidth(16);
    }

    private void initAnimator() {
        mProgressAnim = ObjectAnimator.ofInt(this, "progress", 0, 360);
        mProgressAnim.setDuration(5000);
        mProgressAnim.setInterpolator(null);
    }

    public int getProgress() {
        return mProgress;
    }

    public void setProgress(int progress) {
        mProgress = progress;
        invalidate();
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);

        int width = MeasureSpec.getSize(widthMeasureSpec);
        int height = MeasureSpec.getSize(heightMeasureSpec);  

        int centerX = width / 2;
        int centerY = height / 2;
        int offset = Math.min(centerX, centerY) / 2;

        mArcRectF = new RectF(centerX - offset, centerY - offset, centerX + offset, centerY + offset);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);

        Log.d(TAG, "onDraw() ---> mProgress=" + mProgress);
        canvas.drawArc(mArcRectF, 90, mProgress, false, mPaint);
        mProgressAnim.start();
    }
}

我的想法是通过mProgress来逐渐的将圆弧扩大,但实际效果是这个值一直为0,这个属性动画还是没搞明白

  • 写回答

1条回答 默认 最新

  • leen_wei 2019-04-18 16:09
    关注

    唉,终于知道怎么回事了,原来是onDraw里面的 mProgressAnim.start();处理有问题,需要添加一个判断:
    if(!isAnimationRunning) {
    isAnimationRunning = true;
    mProgressAnim.start();
    }
    否则像上面这样就会陷入类似死循环,不停的调用start,想想刚才真是脑子进水了。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 空间转录组CRAD遇到问题
  • ¥20 materialstudio计算氢键脚本问题
  • ¥15 有没有代做有偿主要做数据可视化部分即可(2023全国高考更省一本线理科类)
  • ¥15 配置FPT报错,该如何处理
  • ¥15 请大家看一下这个代码咋写,一点思路都没有,最好能做一下,不要伪代码,有偿
  • ¥15 有偿请人帮写个安卓系统下禁止装软件及禁止拷入文件的程序
  • ¥100 用 H.265 对音视频硬编码 (CUDA)
  • ¥20 mpich安装完成后出问题
  • ¥15 stm32循迹小车代码问题
  • ¥15 输入一堆单词,使其去重输出