2013-05-13 17 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

+0

私はダッシュラインを描画するビューを作成しました。詳細はこちら[こちら](http://stackoverflow.com/a/15492685/1251276) – ruidge

答えて

47

あなたがラインに

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

を描いている。これは、(onDrawで

ソリューション

 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)); 

線を描画します)

 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); 
     } 
    } 
} 

ニーズに応じて上記を変更します。

関連する問題