Реализация алгоритма Scanline

Я пытаюсь реализовать алгоритм заполнения линий сканирования для случайных треугольников, заданных 3 точками в виде массивов и цвета. Я получаю странные результаты. Пожалуйста, игнорируйте оптимизацию кода, я просто пытаюсь заставить его работать, а затем пытаюсь оптимизировать его. У меня есть метод, который использует алгоритм линий Брезенхэма для рисования линий. Я не могу понять, почему я получаю эти результаты. http://postimg.org/image/qh1sdizwv/

    var dx1;
    var dx2;
    var dx3;

    var S= new Int32Array([0,0]);
    var E= new Int32Array([0,0]);

    var A=new Int32Array([0,0]);
    var B=new Int32Array([0,0]);
    var C=new Int32Array([0,0]);

    var xmin = Math.min(v0[0],v1[0],v2[0]);
    var xmax = Math.max(v0[0],v1[0],v2[0]);
    var ymin = Math.min(v0[1],v1[1],v2[1]);
    var ymax = Math.max(v0[1],v1[1],v2[1]);

    /*A,B and C are points sorted by y-coordinates
      A[1] is ymin, C[1] is ymax
      S is for start, E is for end*/

    if((ymin==v0[1]) && (ymax==v2[1])){
      A[0]=v0[0];
      A[1]=v0[1];
      B[0]=v1[0];
      B[1]=v1[1];
      C[0]=v2[0];
      C[1]=v2[1];
    }

    if((ymin==v0[1]) && (ymax==v1[1])){
      A[0]=v0[0];
      A[1]=v0[1];
      B[0]=v2[0];
      B[1]=v2[1];
      C[0]=v1[0];
      C[1]=v1[1];
    }

    if((ymin==v1[1]) && (ymax==v2[1])){
      A[0]=v1[0];
      A[1]=v1[1];
      B[0]=v0[0];
      B[1]=v0[1];
      C[0]=v2[0];
      C[1]=v2[1];
    }

    if((ymin==v1[1]) && (ymax==v0[1])){
      A[0]=v1[0];
      A[1]=v1[1];
      B[0]=v2[0];
      B[1]=v2[1];
      C[0]=v0[0];
      C[1]=v0[1];
    }

    if((ymin==v2[1]) && (ymax==v0[1])){
      A[0]=v2[0];
      A[1]=v2[1];
      B[0]=v1[0];
      B[1]=v1[1];
      C[0]=v0[0];
      C[1]=v0[1];
    }

    if((ymin==v2[1]) && (ymax==v1[1])){
      A[0]=v2[0];
      A[1]=v2[1];
      B[0]=v0[0];
      B[1]=v0[1];
      C[0]=v1[0];
      C[1]=v1[1];
    }

    if(B[1]-A[1] >0)
      dx1=((B[0]-A[0])/(B[1]-A[1]));
    else
      dx1=0;

    if(C[1]-A[1] >0)
      dx2=((C[0]-A[0])/(C[1]-A[1]));
    else
      dx2=0;

    if(C[1]-B[1] >0)
      dx3=((C[0]-B[0])/(C[1]-B[1]));
    else
      dx3=0;

    S[0]=A[0];
    S[1]=A[1];
    E[0]=A[0];
    E[1]=A[1];

    if(dx1>dx2){
      for(;S[1]<=B[1]; S[1]++, E[1]++, S[0]=S[0]+dx2, E[0]=E[0]+dx1)
        bresenhamAlg(S,E,color);

      E[0]=B[0];
      E[1]=B[1];
      for(;S[1]<=C[1]; S[1]++, E[1]++, S[0]=S[0]+dx2, E[0]=E[0]+dx3)
        bresenhamAlg(S,E,color);
    }

    else{
      for(;S[1]<=B[1]; S[1]++, E[1]++, S[0]=S[0]+dx1, E[0]=E[0]+dx2)
        bresenhamAlg(S,E,color);

      S[0]=B[0];
      S[1]=B[1];
      for(;S[1]<=C[1]; S[1]++, E[1]++, S[0]=S[0]+dx3, E[0]=E[0]+dx2)
        bresenhamAlg(S,E,color);
    }

0 ответов

Другие вопросы по тегам