关于自定义圆环或者小圆球

来源:互联网 发布:js生成年月日时分秒 编辑:程序博客网 时间:2024/04/20 12:08

关于自定义控件,我最近要写的一个项目里要做圆环的复杂效果,因为接触这个不多,所以我就上网找,一找,MP都是好复杂,找了几十个博客才融汇成功,下面我就简单的介绍一下这个吧,

其实圆环不难,但是被复杂化了,

  @Override    protected void onDraw(Canvas canvas) {        super.onDraw(canvas);        // 对于画笔        Paint paint = new Paint();// 设置抗锯齿        paint.setAntiAlias(true);// 设置画笔颜色// 三种样式--Stroke 只要描边 Fill 填充 FILL_AND_STROKE和既有描边又有填充        paint.setStyle(Paint.Style.STROKE);//设置描边宽度        paint.setStrokeWidth(2);//定义外圈员的颜色        paint.setColor(Color.RED);//绘制圆形进度条--获取当前控件多大,正好让进度条在这个控件区间内        canvas.drawCircle(getMeasuredWidth()/2, getMeasuredHeight()/2,100, paint);    }
这样直接就实现了,但是好多都给他加进度条啊百分比啊什么的,介绍也不太清晰,所以找了几十个博客才完成

大家如果想往里面加东西也不难比如我要画一个加号可以酱紫做''

 //文字的绘制        paint.setTextSize(40);//设置文字宽度        paint.setStrokeWidth(1.0f);//测量文字大小-提前准备个矩形        Rect bounds = new Rect();//测量文字的宽和高,测量的值可以根据矩形获取        paint.getTextBounds("+", 0, "+".length(), bounds);        paint.setColor(Color.BLACK);        paint.setStyle(Paint.Style.FILL);//绘制文字,计算文字的宽高进行设置        canvas.drawText("+", getMeasuredWidth()/2 - bounds.width() / 2,                getMeasuredWidth()/2 + bounds.height() / 2, paint);    }



原创粉丝点击