2013-05-13 107 views
15

如何在画布上绘制虚线。我已经试过了:在画布上绘制虚线

Paint dashPaint = new Paint(); 
dashPaint.setARGB(255, 0, 0, 0); 
dashPaint.setStyle(Paint.Style.STROKE); 
dashPaint.setPathEffect(new DashPathEffect(new float[]{5, 10, 15, 20}, 0)); 
canvas.drawLine(0, canvas.getHeight()/2, canvas.getWidth(), canvas.getHeight()/2, dashPaint); 

它给了我不是虚线,而是一个简单的。

+0

你需要用手指画虚线吗? – Raghunandan 2013-05-13 18:43:50

+0

我写了一个绘制虚线的视图。你可以看到细节[here](http://stackoverflow.com/a/15492685/1251276) – ruidge 2013-11-21 08:16:48

回答

47

你画一条线

canvas.drawLine(0, canvas.getHeight()/2, canvas.getWidth(), canvas.getHeight()/2, dashPaint) 

这将画一条线

解决方案

 private Path mPath; 
     mPath = new Path(); 
     mPath.moveTo(0, h/2); 
     mPath.quadTo(w/2, h/2, w, h/2); 
     h and w are height and width of the screen 
     Paint mPaint = new Paint(); 
     mPaint.setARGB(255, 0, 0, 0); 
     mPaint.setStyle(Paint.Style.STROKE); 
     mPaint.setPathEffect(new DashPathEffect(new float[]{5, 10, 15, 20}, 0)); 

在的onDraw()

 canvas.drawPath(mPath, mPaint); 

快照

enter image description here

我有背景和虚线画了它。

public class FingerPaintActivity extends Activity { 
    MyView mv; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     mv = new MyView(this); 
     setContentView(mv); 
     mPaint = new Paint(); 
     mPaint.setAntiAlias(true); 
     mPaint.setDither(true); 
     mPaint.setColor(0xFFFF0000); 
     mPaint.setARGB(255, 0, 0, 0); 
     mPaint.setStyle(Paint.Style.STROKE); 
     mPaint.setPathEffect(new DashPathEffect(new float[]{10, 40,}, 0)); 
     mPaint.setStrokeWidth(12); 
    } 

    private Paint mPaint; 

    public class MyView extends View { 
     private Bitmap mBitmap; 
     private Canvas mCanvas; 
     private Path mPath; 
     private Paint mBitmapPaint; 
     Context context; 

     public MyView(Context c) { 
      super(c); 
      context = c; 
      mPath = new Path(); 
      mBitmapPaint = new Paint(Paint.DITHER_FLAG); 
     } 

     @Override 
     protected void onSizeChanged(int w, int h, int oldw, int oldh) { 
      super.onSizeChanged(w, h, oldw, oldh); 
      mBitmap = Bitmap.createBitmap(w, h, Bitmap.Config.ARGB_8888); 
      mCanvas = new Canvas(mBitmap); 
      mPath.moveTo(0, h/2); 
      mPath.quadTo(w/2, h/2, w, h/2); 
     } 

     @Override 
     protected void onDraw(Canvas canvas) { 
      super.onDraw(canvas); 
      canvas.drawBitmap(mBitmap, 0, 0, mBitmapPaint); 
      canvas.drawPath(mPath, mPaint); 
     } 
    } 
} 

根据需要修改以上。