自定义view,点击更换背景色与随机数

本文介绍了一个自定义Android视图的实现方法,通过继承AppCompatTextView并重写onDraw方法来绘制随机颜色的矩形及四位数字,同时通过触摸事件改变其颜色。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class MyView extends AppCompatTextView {

    private Paint paint;
    private boolean flag=true;
    private void init(){
        paint = new Paint();
        //设置抗锯齿
        paint.setAntiAlias(true);
    }
    public MyView(Context context) {
        super(context);
        init();
    }
    public MyView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }
    public MyView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        init();
    }
    @Override
    protected void onDraw(Canvas canvas) {
        //四位随机数
        int s = (int) (Math.random() * 9000) + 1000;
        //在屏幕上画一个矩形
        paint.setStyle(Paint.Style.FILL);
        if(flag == true){
            paint.setColor(Color.RED);
        }else {
            paint.setColor(Color.BLUE);
        }
        //在屏幕上画一个矩形
        canvas.drawRect(100,100, 200,150,paint);
        if(flag == true){
            paint.setColor(Color.BLACK);
        }else {
            paint.setColor(Color.RED);
        }
        paint.setTextSize(22);
        canvas.drawText(s+"",120,130,paint);
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {
        if (event.getAction() == MotionEvent.ACTION_DOWN){
        }else if(event.getAction() == MotionEvent.ACTION_MOVE){
        }else {
            invalidate();
            if(flag == true){
                flag = false;
            }else {
                flag = true;
            }
        }
        return true;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值