-1

我编辑了 MyLine 和 CanvasView 但现在我画了法线和虚线但之后我点击法线并画了虚线。下来你有 mt 编辑代码。在 MyLine 中创建私有绘图后,来自 onDraw 的 line.paint 被转换为 getPaint

Here you have MyLine.java

    public class MyLine { //  line
    public float x,y;
    public float xStart,yStart,xEnd,yEnd;
    private boolean drawDashed;
    private Paint paint = new Paint();

public MyLine(boolean drawDashed)
{
    if(drawDashed){
    getPaint().setColor(Color.BLUE);
    getPaint().setStyle(Paint.Style.STROKE);
    getPaint().setPathEffect(new DashPathEffect(new float[]{20,30}, 0));
    getPaint().setAntiAlias(true);
    getPaint().setStrokeJoin(Paint.Join.ROUND);
    getPaint().setStrokeWidth(5f);
    } else{ 
        getPaint().setColor(Color.RED);
        getPaint().setStyle(Paint.Style.STROKE);
        getPaint().setPathEffect(null);
        getPaint().setAntiAlias(true);
        getPaint().setStrokeJoin(Paint.Join.ROUND);
        getPaint().setStrokeWidth(5f);
    }
}

public void mouseDown(Path path,float xDown,float yDown){
    //path.moveTo(xDown, yDown);
//  path.lineTo(xDown, yDown);

    xStart = xDown;
    yStart = yDown;
}

public void mouseUp(Path path,float xUp,float yUp){
    //path.lineTo(xUp, yUp);
    xEnd = xUp;
    yEnd = yUp;
}

public void draw(Canvas c){
    getPaint().setColor(Color.GREEN);
    //paint.setStyle(Paint.Style.STROKE);
    getPaint().setPathEffect(new DashPathEffect(new float[]{10,20}, 0));
    getPaint().setAntiAlias(true);
    getPaint().setStrokeJoin(Paint.Join.ROUND);
    getPaint().setStrokeWidth(5f);

    c.drawLine(xStart,yStart,xEnd,yEnd,getPaint());
}

public Paint getPaint() {
    return paint;
}

public void setPaint(Paint paint) {
    this.paint = paint;
}

这是来自 CanvasView.java

protected void onDraw(Canvas canvas) {
    paint.setPathEffect(null);
    if(bitmap!=null){

        canvas.drawBitmap(bitmap, 0, 0, paint);
         for(MyCircle circle:circleList){// draw circles

             myCanvas.drawCircle(getCircleMidPointX(circle.firstX, circle.lastX),getCircleMidPointY(circle.firstY, circle.lastY),circle.radius,myPaint);
         }

    }

    for (Path p : paths){
        canvas.drawPath(p, paint);
    }
    canvas.drawPath(path, paint);


     for(MyLine line:lineList){ //draw lines
         canvas.drawLine(line.xStart, line.yStart, line.xEnd, line.yEnd, line.getPaint());
      }
final OnTouchListener drawLineListener = new OnTouchListener() {
        public boolean onTouch(View v, MotionEvent event) {

            FirstActivity.ll.setVisibility(LinearLayout.GONE);

            switch (event.getAction()) {
              case MotionEvent.ACTION_DOWN:
                  myLine = new MyLine(dashedLine);
                  myLine.xStart = event.getX();
                  myLine.yStart = event.getY();

                return true;

              case MotionEvent.ACTION_MOVE:
              case MotionEvent.ACTION_UP:
                myLine.xEnd = event.getX();
                myLine.yEnd = event.getY();
                invalidate();
                lineList.add(myLine); 
                break;

              default:
                Log.d("mock it up", "Unknown touch event  " + event.toString());
                return false;
            }
            return true;

        }
    };

    final OnTouchListener drawDashedLineListener = new OnTouchListener() {
        public boolean onTouch(View v, MotionEvent event) {

            FirstActivity.ll.setVisibility(LinearLayout.GONE);

            switch (event.getAction()) {
              case MotionEvent.ACTION_DOWN:
                 return true;

              case MotionEvent.ACTION_MOVE:
              case MotionEvent.ACTION_UP:

                break;

              default:
                Log.d("mock it up", "Unknown touch event  " + event.toString());
                return false;
            }
            return true;

        }
    };
4

2 回答 2

1

b 在 onDraw()

 if(dashedLine)
     line.paint.setPathEffect(dashEffect);
 else
     line.paint.setPathEffect(null);

您正在重置所有线条的效果,这就是正在绘制的内容:全部虚线或全部正常

您可能想要做的是给每个 MyLine 自己的属性:

boolean drawDashed =true/false;

并让它相应地绘制自己(用正确的 dasheffect 选择正确的油漆)

于 2013-03-29T18:04:01.790 回答
0
public class MyLine { //  line

public float x,y;
    public float xStart,yStart,xEnd,yEnd;
    private boolean drawDashed;
    private Paint paint = new Paint();
    public MyLine(boolean drawDashed)
    {
      if(drawDashed){
        ...
        paint.setPathEffect(new DashPathEffect(new float[]{10,20}, 0));
        ....
      } else{  
         ....
         paint.setPathEffect(null);
         ...
      }
    }

public void mouseDown(Path path,float xDown,float yDown){
    //path.moveTo(xDown, yDown);
//  path.lineTo(xDown, yDown);

    xStart = xDown;
    yStart = yDown;
}

public void mouseUp(Path path,float xUp,float yUp){
    //path.lineTo(xUp, yUp);
    xEnd = xUp;
    yEnd = yUp;
}

public void draw(Canvas c){

    c.drawLine(xStart,yStart,xEnd,yEnd,paint);
}

}

所以向 Myline 添加两个私有属性,这样它自己的线条就知道如何绘制自己:

private boolean drawDashed;
private Paint paint = new Paint();

那么draw方法就变得很简单了:

public void draw(Canvas c){    
    c.drawLine(xStart,yStart,xEnd,yEnd,paint);
}
于 2013-03-29T19:41:54.653 回答