在画布上绘制2个圆圈

时间:2013-01-21 11:50:08

标签: android graphics canvas

我试图像这样绘制两个圆圈:

enter image description here

这就是我尝试这样做的方式:

Bitmap bmp = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_4444);

Canvas c = new Canvas(bmp);

RectF rect = new RectF(0,0,width,width);
Paint paint = new Paint();
drawCircles(paint, c, width, height, width);
ImageView img = (ImageView) findViewById(R.id.imageView1);
img.setImageBitmap(bmp);
img.setScaleType(ScaleType.FIT_CENTER);

这是我的drawCircles()方法:

private void drawCircles(Paint paint, Canvas c, int width, int height, int radius) {
        paint.setARGB(255, 255 , 10, 21);
        paint.setStrokeWidth(10);
        paint.setAntiAlias(true);
        paint.setStrokeCap(Paint.Cap.BUTT);
        paint.setStyle(Paint.Style.STROKE);
        if(width < height && radius == 0){
            radius = width/2;
            height = width;
        } else if (radius == 0){
            radius = height/2;
            width = height;
        }
        Paint paint2 = new Paint();
        paint2.setARGB(255, 255 , 10, 21);
        paint2.setStrokeWidth(10);
        paint2.setAntiAlias(true);
        paint2.setStrokeCap(Paint.Cap.BUTT);
        paint2.setStyle(Paint.Style.STROKE);
        c.drawCircle(width/2, height/2, radius-10, paint);
        c.drawCircle(width/2, height/2, 50, paint2);
}

我不知道为什么,但我只得到一个圆圈,小圆圈(用paint2绘制的圆圈)。 可能是什么原因?

1 个答案:

答案 0 :(得分:2)

试试这段代码。希望它可以帮助:)

public class SimpleCircleActivity extends Activity
{

       private CircleDemoView circledemoView ;

       public void onCreate(Bundle savedInstanceState)
       { 
        super.onCreate(savedInstanceState);

        circledemoView =new CircleDemoView(this);
        setContentView(circledemoView);

       }


       private class CircleDemoView extends View
       {
         public CircleDemoView(Context context)
         {
             super(context);
         }

         @Override
         protected void onDraw(Canvas canvas) 
         {

             super.onDraw(canvas);
             Paint p = new Paint();
             p.setColor(Color.RED);
             DashPathEffect dashPath = new DashPathEffect(new float[]{5,5}, (float)1.0);

             p.setPathEffect(dashPath);
             p.setStyle(Style.STROKE);


             for (int i = 0; i < 2; i ++) {
                 canvas.drawCircle(200, 200, 50+(i*40), p);
             }


             invalidate();

     }
     }

}