我套路的自定义View 定时器(三)

上一篇(http://www.cnblogs.com/jaelyn/p/6644194.html)通过手势来改变小球的位置,这次我们使用一个定时器来改变小球的各种状态,这样就能够做出各种动画效果。

效果图:

 

代码如下:

public class MyView extends View {
    private String TAG = "MyView";
    private Paint paint;

    private Timer timer;
    private TimerTask task;

    private float radius = 100;
    private int alpha = 255;
    private float x, y;
    private float scale = 1;
    private boolean state = false;

    public MyView(Context context) {
        super(context);
        initView();
    }

    public MyView(Context context, AttributeSet attrs) {
        super(context, attrs);
        initView();
    }

    public MyView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        initView();
    }

    public void initView() {
        Log.d(TAG, "onCreat");
        paint = new Paint();
        paint.setColor(Color.RED);
        timer = new Timer();
        task = new TimerTask() {
            @Override
            public void run() {
                if (!state) {
                    scale -= 0.01;
                    if (scale < 0) {
                        state = true;
                        scale = 0f;
                    }
                }else {
                    scale += 0.01;
                    if (scale > 1){
                        state = false;
                        scale = 1f;
                    }
                }
                paint.setAlpha((int) (alpha * scale));
                postInvalidate();
            }
        };
    }

    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        Log.d(TAG, "onSizeChanged");
        super.onSizeChanged(w, h, oldw, oldh);
        x = w / 2;
        y = h / 2;
    }

    @Override
    protected void onDraw(Canvas canvas) {
        Log.d(TAG, "onDraw");
        super.onDraw(canvas);
        canvas.drawCircle(x, y, radius * scale, paint);
    }

    public void starAnim() {
        timer.schedule(task, 1000, 20);
    }
}

启动timer每隔20毫秒计算 缩放比例、更新页面。

缩放比例沿 1 -> 0 -> 1 变化。

通过画笔设置透明度 范围为 ( 0, 255);

圆点的半径范围:(0, 100);

在通过 view对象开启开启动画 myView.starAnim(); 

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        MyView myView = (MyView) findViewById(R.id.myview);
        myView.starAnim();
    }
}

 

转载于:https://www.cnblogs.com/jaelyn/p/6645089.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值