Module 2
Module 2
Module 2
VIEWING IN 2D
A world-coordinate area selected for display is called a window. An area on a display device to which a window is mapped is called a viewport. The window defrnes what is to be viewed: the viewport defines where it is to be displayed. Thus to display the appropriate images on the screen (or other device) it is necessary to map from world coordinates to screen or device coordinates. This transformation is known as the window to viewport transformation, the mapping from the world coordinate window to the viewport (which is given in screen coordinates).
In general the window to viewport transformation will involve a scaling and translation where the scaling in non-uniform (the vertical axis has been stretched). The transformation is generally achieved by a translation in world coordinates, a scaling to viewport coordinates and another translation in viewport coordinates, which are generally composed to give a single transformation matrix.
The required transformations are shown in Figure If the world coordinate window has dimensions (xmin; ymin) (xmax; ymax) and the viewport (or screen coordinate window) has dimensions (umin; vmin) (umax; vmax), then the transformation will be given by: a translation;
a scaling:
CLIPPING Remove points outside a region of interest. Discard (parts of) primitives outside our window. Point clipping: o Remove points outside window. o A point is either entirely inside the region or not. Line clipping: o Remove portion of line segment outside window. o Line segments can straddle the region boundary.
POINT CLlPPlNG Assuming that the clip window is a rectangle in standard position, we save a point P = (x, y) for display if the following inequalities are satisfied: xwminxxwmax ywminyywmax Where the edges of the clip window (xwmin, xwmax, ywmin , ywmax) can be either the world-coordinate window boundaries or viewport boundaries. If any one of these four inequalities is not satisfied, the point is clipped (not saved for display). Although point clipping is applied less often than line or polygon clipping, some applications may require a point clipping procedure. LINE CLIPPING Lines intersecting a rectangular clip region are always clipped to a single line segment. Figure shows examples of clipped lines.
CLIPPING ENDPOINTS If the x coordinate boundaries of the clip rectangle are at xmin and xmax and the y coordinate boundaries are at ymin, and ymax, the following conditions must be satisfied for a point at (x, y) to be inside the clip rectangle If any of the above conditions do not hold, the point is outside the clip rectangle
From the above figure, these lines that are partly invisible are divided by the screen boundary in to one or more invisible portions but in to only one visible segment. Visible segment of a straight line can be determined by computing its 2 endpoints.
The Cohen- Sutherland algorithm is designed to find these end points very rapidly but also to reject even more rapidly any line that is clearly invisible. This makes it a very good algorithm for clipping pictures that are much larger than the screen.
The algorithm has 2 parts. The first part determines whether the line lies entirely on the screen, then it will be accepted and if not whether the line can be rejected if lying entirely off the screen. If it satisfies none of these 2 tests, then the line is divided in to 2 parts and these 2 tests are applied to each part. The algorithm depends on the fact that every line is entirely on the screen. Or can be divided so that one part can be rejected. We are extending the edges of the screen so that they divide the space occupied by the unclipped picture in to 9 regions. Each of these regions has a 4 bit code.
If the logical AND of the 2 codes is not zero, then the line will be entirely off the screen. For example, for line GH, the logical AND of the 2 end points is 0100. it is not equal to zero, so the line is completely out of the screen. If the 4 bit codes for both endpoints are zero, the line lies entirely on the screen. For example, for line CD, the 4 bit codes for both endpoints C, D are 0000. So the line lies entirely inside the screen. If both these tests are not successful, it means that a part of a line is inside and a part is outside the screen.
For example line AB. Then such lines are subdivided. A simple method of sub division is to find the point of intersection of the line with one edge of the screen and to discard that part of the line that lies off the screen.
For line BC, we apply the same tests. The line cannot be rejected, so we again subdivide it at point D. the resulting line BD is entirely on the screen.
The algorithm works as follows. We compute the out codes of both endpoints and check for trivial acceptance and rejection.
If both tests are not successful, we find an end point that lies outside and test the out code to find the edge that is crossed and to determine the corresponding intersection point. We can clip off the line segment from the outside end point to the intersection point by replacing the outside end point with the intersection point and compute the outside of this new end point to prepare for the next iteration.
Point A has out code 0000 and point D has out code 1001. The line AD cannot be accepted and cannot be rejected. Therefore the algorithm chooses D as the outside point, whos out code shows that the line crosses the top edge and left edge. In this algorithm we choose the top edge of the screen to clip and we clip AD to AB. We compute Bs out code as 0000. In our next iteration, we apply the trivial acceptance/ rejection tests to AB, and the line is accepted and displayed.
EI requires more iteration. The first end point E has out code 0100. The algorithm chooses E as the outside point and tests the out code to find the first edge against which the line is cut is the bottom edge, where EI is clipped top FI. In the second iteration, FI cannot be completely accepted or rejected.
The out code of the first end point, F is 0000, so the algorithm chooses the outside point I that has out code 1010.
The first edge clipped against is the top edge, yielding FH. H has the out code 0010. Then the next iteration results in a clip against the right edge to FG. This is accepted in the final iteration and is displayed.
ALGORITHM typedef unsigned int outcode; enum { TOP = 0x1, BOTTOM = 0x2, RIGHT = 0x4, LEFT = 0x8}; void CohenSutherlandClipAndDraw(x0, y0, x1, y1, xmin, xmax, ymin, ymax) double x0, y0, x1, y1, xmin, xmax, ymin, ymax; /* Cohen sutherland clipping algorithm for line P0 = (x0, y0) to P1 = (x1, y1) and clip rectangle with diagonal from (xmin, ymin) to (xmax, ymax) */ { /* outcodes for P0, P1 and whatever point lies outside the clip rectangle. */ outcode outcode0, outcode1, outcodeout; boolean accept = FALSE, done = FALSE; outcode0 = compoutcode (x0, y0, xmin, xmax, ymin, ymax); outcode1 = compoutcode (x1, y1, xmin, xmax, ymin, ymax); do { if ( ! (outcode0 | outcode1)) { /* accept and exit */ accept = TRUE; done = TRUE; } else if ( outcode0 && outcode1) /* logical AND is true, so reject and exit */ done = TRUE; else
{ /* failed both tests, so calculate the line segment to clip */ /* from an outside point to an intersection with clip edge */ double x, y; /* at least one end point is outside the clip rectangle, find it */ if (outcode0) outcodeout = outcode0; else outcodeout = outcode1; /* now find the intersection point */ /* use formulas y = y0 + slope * (x x0) */ /* x = x0 + (1/slope) * y y0) */ if (outcodeout && TOP) /* Divide line at top of clip rectangle*/ { x = x0 + (x1 x0) * (ymax y0) / y1 y0); y = ymax; } else if (outcodeout && BOTTOM) /* Divide line at bottom edge of clip rectangle*/ { x = x0 + (x1 x0) * (ymin y0) / y1 y0); y = ymin; } else if (outcodeout && RIGHT) /* Divide line at right edge of clip rectangle*/ { y = y0 + (y1 y0) * (xmax x0) / x1 x0); x = xmax; } else /* Divide line at left edge of clip rectangle*/ { y = y0 + (y1 y0) * (xmin x0) / x1 x0); x = xmin; } /* now we move outside point to intersection point to clip */ /* and get ready for next pass */ if (oucodeout == outcode0) { x0 = x; y0 = y; outcode0 = compoutcode (x0, y0, xmin, xmax, ymin, ymax); } else { x1 = x; y1 = y; outcode1 = compoutcode (x1, y1, xmin, xmax, ymin, ymax); } } }while (done = = FALSE); if (accept) drawline ( x0, y0, x1, y1); }
outcode compoutcode ( x, y, xmin, xmax, ymin, ymax) double x, y, xmin, xmax, ymin, ymax; { outcode code = 0; if (y > ymax) code = code || TOP; else if (y < ymin) code = code || BOTTOM; if (x > xmax) code = code || RIGHT; else if (x < xmin) code = code || LEFT; return code; } MIDPOINT SUBDIVISON ALGORITHM This algorithm is based on the bisection method. According to this method, we calculate the mid value of a line using the endpoints value and then we divide the line into two line segments. Each segment in partially visible category is divided again into smaller segments and categorized. The bisection and categorization process continuous until the entire segment are in visible or invisible category. The midpoint coordinates (Xm, Ym) of a line segment P1(X1Y1) p2(X2Y2) are given by: Xm = X1 + X2 / 2 Ym = Y1 + Y2 / 2
Algorithm 1) If every endpoint is in visible area of clipping window, then process is complete else continue next step. 2) If line is not visible then process is complete else continue next step. 3) If line is partially visible then divide line into smaller line segments using bisection method. Then go to step 1. 4) The bisection and categorization process continuous until all the segment are in visible or invisible category