DDA algorithm is the basic algorithm for line drawing.In this method, we start from the starting point and then on each step a fixed increment is added to the current point to get the next point on the line.We repeat these steps till the end of the line.
Let us suppose (x1,y1) and (x2,y2) are the end points of the line and the equation of the line is y=mx+c.
slope of the line=(y2-y1)/(x2-x1)
suppose dx=(x2-x1) and dy=(y2-y1)
dx=dy/m and dy=m*dx
dx and dy will be the values for incrementing x and y values of current point.so-
Xi+1 =Xi + dy/m
Yi+1 =Yi + m*dx
length=abs(x2-x1)
else
length=abs(y2-y1)
X=x1+0.5*SIGN(dx);
Y=y1+0.5*SIGN(dy);
(x1,y1) will be initial coordinates.
{
plot(int(x),int(y));
Xi+1 =Xi + dx;
Yi+1 =Yi + dy;
i=i+1;
}
Let us suppose (x1,y1) and (x2,y2) are the end points of the line and the equation of the line is y=mx+c.
slope of the line=(y2-y1)/(x2-x1)
suppose dx=(x2-x1) and dy=(y2-y1)
dx=dy/m and dy=m*dx
dx and dy will be the values for incrementing x and y values of current point.so-
Xi+1 =Xi + dy/m
Yi+1 =Yi + m*dx
DDA Algorithm-
- Read the points (x1,y1) and (x2,y2)
- approximate the length of line i.e. if
length=abs(x2-x1)
else
length=abs(y2-y1)
- Select the raster unit dx and dy
- Round the value rather than truncating, make use of SIGN function so as to enable line drawing in any quadrant
X=x1+0.5*SIGN(dx);
Y=y1+0.5*SIGN(dy);
(x1,y1) will be initial coordinates.
- now plot the points and i=1
{
plot(int(x),int(y));
Xi+1 =Xi + dx;
Yi+1 =Yi + dy;
i=i+1;
}
- stop
Advantage of DDA algorithm-
The only advantage of DDA algorithm is that it is the simplest algorithm for line drawing.Drawbacks of DDA algorithm-
- While plotting we are taking either abs(y2-y1) or abs(x2-x1) as length which makes this orientation dependent, so it may posible that end point
DDA algorithm in c-
#include<stdio.h> #include<math.h> #include<graphics.h> //structure for two end points struct point{ int x,y; }a,b; int main() { int dx,dy,delx,dely,len,i,gd,gm; printf("enter two pair of points\n"); scanf("%d %d",&a.x,&a.y); scanf("%d %d",&b.x,&b.y); dx=abs(b.x-a.x); dy=abs(b.y-a.y); if(dx>dy) len=dx; else len=dy; delx=dx/len; dely=dy/len; i=1; initgraph(&gd,&gm,""); if(len<0) len=-len; while(i<=len) { putpixel(a.x,a.y,RED); a.x=a.x+delx; a.y=a.y+dely; i++; delay(10); } getchar(); closegraph(); return 0; }
OUTPUT-
- To execute the program save the file given above with .c extension i.e. (dda.c)
- open your terminal and type gcc dda.c -lgraph and click enter button
- run ./a.out and see the output
- output given below is for end points (10,10) and (100,100)
Comments
Post a Comment