2013-05-13 110 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); 
     } 
    } 
} 

根據需要修改以上。