Bresenham的线算法出错

时间:2015-08-28 19:24:02

标签: java bresenham

我试图填充一个带星星(*)的矩阵来绘制Bresenham的线条,但是当我打印出来的东西时,矩阵只填充了一颗星我不会#39我知道什么是错的。语言是Java

public class PtLine extends VectorObject{   // inherites from another class
private int bx;
private int by;
private int delX;
private int delY;

public PtLine(int id,int x,int y,int bx,int by){
     super(id,x,y);
     this.bx = bx;
     this.by = by;
     this.delX = this.bx-x;
     this.delY = this.by-y;

 }
 public void draw ( char [][] matrix ){    // filling the martic with stars
    int D = 2*delY - delX;
    matrix[x][y] = '*';
    int j = y;

    for (int i=x+1;i==bx;i++){
       if(D > 0){
          j+=1;
          matrix[i][j]='*';
          D = D + (2*delY-2*delX);
       }
      else{
         matrix[i][j]='*';
         D = D + (2*delY);
      } 
    } 
 }     

}

以下代码是我试图打印出矩阵

  class Question3{
     public static void main ( String args [] ){


     char[][] matrix = new char[20][20];
     for (int y = 0; y < 20; y++) {
        for (int x = 0; x < 20; x++) {
            matrix[y][x] = ' ';
         }
      }

     PtLine n = new PtLine(6,6,6,13,13);
     n.draw(matrix);
     for (int y = 0; y < 20; y++) {
        for (int x = 0; x < 20; x++) {
            System.out.print(matrix[x][y]);
         }
         System.out.println();
     } 
 }

}

1 个答案:

答案 0 :(得分:0)

您可能需要使用i==bx更改i!=bx

public void draw ( char [][] matrix ){    // filling the martic with stars
  int D = 2*delY - delX;
  matrix[x][y] = '*';
  int j = y;

  for (int i=x+1;i!=bx;i++){ // here
  ...
  }
}

当此条件为真时,for循环继续。在您的代码循环中,在第一次迭代之前立即完成,因为此条件为false。