The digital differentia analyzer (DDA) is a scan-conversion
line algorithm. In this algorithm, we sample the line at unit intervals
in one coordinate and determine corresponding integer values nearest the
line path of the other coordinate and plot those coordinate (pixel) in
computer screen. Consider first a line with positive slope. If the slope
is less than or equal to 1, we sample at unit x intervals (dx = 1) and computer each successive y value as y(k+1) = y(k) + m. Subscript k
takes integer values starting from 1, for the first point, and
increases by 1 until the final endpoint is reached. For lines with a
positive slope greater than 1, we reverse the roles of x and y.That is, we sample at unit y intervals (dy = 1) and calculate each succeeding x value as x(k+1) = x(k) + (1/m)
The following section implements DDA Algorithm in C/C++. The source code is complied using gcc Compiler and Code::Blocks IDE. To print a pixel, SetPixel() function of windows.h is used.
#include <windows.h>#include <cmath>#define ROUND(a) ((int) (a + 0.5))
/* set window handle */
static HWND sHwnd;
static COLORREF redColor=RGB(255,0,0);
static COLORREF blueColor=RGB(0,0,255);
static COLORREF greenColor=RGB(0,255,0);
void SetWindowHandle(HWND hwnd){
sHwnd=hwnd;}/* SetPixel */
void setPixel(int x,int y,COLORREF& color=redColor){if(sHwnd==NULL){
MessageBox(NULL,"sHwnd was not initialized !","Error",MB_OK|MB_ICONERROR);exit(0);
}HDC hdc=GetDC(sHwnd);SetPixel(hdc,x,y,color);ReleaseDC(sHwnd,hdc);return;
// NEVERREACH //
}void drawLineDDA(int xa, int ya, int xb, int yb){int dx = xb - xa, dy = yb - ya, steps, k;
float xIncrement, yIncrement, x = xa, y = ya;
if(abs(dx) > abs(dy)) steps = abs(dx);else steps = abs(dy);xIncrement = dx / (float) steps;
yIncrement = dy / (float) steps;
setPixel(ROUND(x), ROUND(y));for(int k = 0; k < steps; k++){x += xIncrement;y += yIncrement;setPixel(x, y);}}/* Window Procedure WndProc */
LRESULT CALLBACK WndProc(HWND hwnd,UINT message,WPARAM wParam,LPARAM lParam){switch(message){
case WM_PAINT:
SetWindowHandle(hwnd);drawLineDDA(10, 20, 250, 300);break;
case WM_CLOSE: // FAIL THROUGH to call DefWindowProcbreak;
case WM_DESTROY:
PostQuitMessage(0);return 0;
default:
break; // FAIL to call DefWindowProc //}return DefWindowProc(hwnd,message,wParam,lParam);
}int WINAPI WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPSTR lpCmdLine,int iCmdShow){static TCHAR szAppName[] = TEXT("Straight Line");WNDCLASS wndclass;wndclass.style = CS_HREDRAW|CS_VREDRAW ;wndclass.lpfnWndProc = WndProc ;wndclass.cbClsExtra = 0 ;wndclass.cbWndExtra = 0 ;wndclass.hInstance = hInstance ;wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION) ;wndclass.hCursor = LoadCursor (NULL, IDC_ARROW) ;wndclass.hbrBackground = (HBRUSH) GetStockObject (WHITE_BRUSH) ;wndclass.lpszMenuName = NULL ;wndclass.lpszClassName = szAppName ;// Register the window //
if(!RegisterClass(&wndclass)){
MessageBox(NULL,"Registering the class failled","Error",MB_OK|MB_ICONERROR);exit(0);
}// CreateWindow //
HWND hwnd=CreateWindow(szAppName,"DDA - Programming Techniques",
WS_OVERLAPPEDWINDOW,CW_USEDEFAULT,CW_USEDEFAULT,CW_USEDEFAULT,CW_USEDEFAULT,NULL,NULL,hInstance,NULL);if(!hwnd){
MessageBox(NULL,"Window Creation Failed!","Error",MB_OK);exit(0);
}// ShowWindow and UpdateWindow //
ShowWindow(hwnd,iCmdShow);UpdateWindow(hwnd);// Message Loop //
MSG msg;while(GetMessage(&msg,NULL,0,0)){
TranslateMessage(&msg);DispatchMessage(&msg);}/* return no error to the operating system */
return 0;
}
The output of this program is looks like
DDA algorithm is faster than the direct use of equation y = mx + c however, the rounding operations and floating-point arithmetic makes it still time consuming. To overcome this limitation of DDA Algorithm, Bresenham discovered Bresenham’s Line Drawing Algorithm.
No comments:
Post a Comment
Comment